日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

1 RPC簡(jiǎn)介

RPC(Remote Procedure Call)—遠(yuǎn)程過(guò)程調(diào)用,它是一種通過(guò)網(wǎng)絡(luò)從遠(yuǎn)程計(jì)算機(jī)程序上請(qǐng)求服務(wù),而不需要了解底層網(wǎng)絡(luò)技術(shù)的協(xié)議。RPC協(xié)議假定某些傳輸協(xié)議的存在,如TCP或UDP,為通信程序之間攜帶信息數(shù)據(jù)。在OSI網(wǎng)絡(luò)通信模型中,RPC跨越了傳輸層和應(yīng)用層。

2 RPC實(shí)現(xiàn)

RPC的實(shí)現(xiàn)中一個(gè)重要的功能就是動(dòng)態(tài)代理。整個(gè)過(guò)程如下:

首先,對(duì)于用戶方而言:

  • 只提供接口不提供實(shí)現(xiàn)類,所有的接口文件都導(dǎo)出后,調(diào)用方放在一個(gè)專門(mén)目錄下
  • 接口千奇百怪,但是都沒(méi)有具體實(shí)現(xiàn)
  • 代理要代理掉專門(mén)目錄下的所有接口,任何對(duì)這里接口的調(diào)用都被序列化后轉(zhuǎn)到遠(yuǎn)端

假設(shè),我們有一個(gè)接口如下:

遠(yuǎn)程過(guò)程調(diào)用RPC的實(shí)現(xiàn)原理:動(dòng)態(tài)代理

只有方法名稱,也不知道接口在遠(yuǎn)端的實(shí)現(xiàn)類的名稱。

然后,我們的ProxyHandler如下:

具體使用時(shí)這樣:

遠(yuǎn)程過(guò)程調(diào)用RPC的實(shí)現(xiàn)原理:動(dòng)態(tài)代理

這樣,就可以實(shí)現(xiàn)RPC的代理了。運(yùn)行結(jié)果:

遠(yuǎn)程過(guò)程調(diào)用RPC的實(shí)現(xiàn)原理:動(dòng)態(tài)代理

那具體實(shí)現(xiàn)RPC可如下。

  • 首先如代碼所示,我們只需要接口,不需要知道任何實(shí)現(xiàn)類的信息就可以創(chuàng)建一個(gè)接口的代理實(shí)現(xiàn)。就和生成RemoteService remoteService一樣。
  • 因?yàn)樗械慕涌诙荚谥付夸浵?,我們可以掃描該目錄下的所有接口,批量生成所有接口的?shí)例,并把生成的bean都放入spring中管理。這樣,用戶就可以用autowair注入所有實(shí)現(xiàn)。而實(shí)際上我們的代理proxy就成了所有接口的實(shí)現(xiàn)。
  • 用戶調(diào)用任何接口時(shí),都調(diào)用了我們生成的bean實(shí)現(xiàn)。其實(shí)都進(jìn)入了我們相同的handler實(shí)現(xiàn),實(shí)現(xiàn)中我們可以知道用戶想要調(diào)用的完整方法名稱(從它的目錄路徑可以分析出目標(biāo)應(yīng)用名)、參數(shù)。然后序列化后去遠(yuǎn)端調(diào)用并返回結(jié)果即可。

3 動(dòng)態(tài)代理

cglib是通過(guò)字節(jié)碼,生成了目標(biāo)類的子類實(shí)現(xiàn)動(dòng)態(tài)代理的。因此,對(duì)于final的方法無(wú)法使用cglib進(jìn)行動(dòng)態(tài)代理。

首先引入Cglib包:

遠(yuǎn)程過(guò)程調(diào)用RPC的實(shí)現(xiàn)原理:動(dòng)態(tài)代理

首先,目標(biāo)對(duì)象不發(fā)生任何變化,并且該類也不需要實(shí)現(xiàn)任何接口了:

遠(yuǎn)程過(guò)程調(diào)用RPC的實(shí)現(xiàn)原理:動(dòng)態(tài)代理

代理類寫(xiě)法如下:

遠(yuǎn)程過(guò)程調(diào)用RPC的實(shí)現(xiàn)原理:動(dòng)態(tài)代理

通過(guò)代碼我們也可以看出,代理類是作為目標(biāo)類的子類出現(xiàn)的,在調(diào)用目標(biāo)類方法時(shí),實(shí)際是調(diào)用父類。

使用如下:

遠(yuǎn)程過(guò)程調(diào)用RPC的實(shí)現(xiàn)原理:動(dòng)態(tài)代理

使用過(guò)程比較簡(jiǎn)單:

1. 生成一個(gè)代理對(duì)象

2. 告訴代理對(duì)象,它的實(shí)現(xiàn)在哪里

3. 告訴代理對(duì)象,它的父類是誰(shuí)

4. 生成代理類的對(duì)象

5. 調(diào)用代理對(duì)象的方法

這樣,對(duì)生成的代理對(duì)象進(jìn)行調(diào)用時(shí),會(huì)調(diào)用到它的回調(diào)對(duì)象,然后回調(diào)對(duì)象中根據(jù)操作可能調(diào)用目標(biāo)對(duì)象(父類)的方法。

得到結(jié)果:

before speak

hello Jack

after speak

OK

分享到:
標(biāo)簽:RPC
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定