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

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

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

1 RPC簡介

RPC(Remote Procedure Call)—遠程過程調用,它是一種通過網絡從遠程計算機程序上請求服務,而不需要了解底層網絡技術的協議。RPC協議假定某些傳輸協議的存在,如TCP或UDP,為通信程序之間攜帶信息數據。在OSI網絡通信模型中,RPC跨越了傳輸層和應用層。

2 RPC實現

RPC的實現中一個重要的功能就是動態代理。整個過程如下:

首先,對于用戶方而言:

  • 只提供接口不提供實現類,所有的接口文件都導出后,調用方放在一個專門目錄下
  • 接口千奇百怪,但是都沒有具體實現
  • 代理要代理掉專門目錄下的所有接口,任何對這里接口的調用都被序列化后轉到遠端

假設,我們有一個接口如下:

遠程過程調用RPC的實現原理:動態代理

只有方法名稱,也不知道接口在遠端的實現類的名稱。

然后,我們的ProxyHandler如下:

具體使用時這樣:

遠程過程調用RPC的實現原理:動態代理

這樣,就可以實現RPC的代理了。運行結果:

遠程過程調用RPC的實現原理:動態代理

那具體實現RPC可如下。

  • 首先如代碼所示,我們只需要接口,不需要知道任何實現類的信息就可以創建一個接口的代理實現。就和生成RemoteService remoteService一樣。
  • 因為所有的接口都在指定目錄下,我們可以掃描該目錄下的所有接口,批量生成所有接口的實例,并把生成的bean都放入spring中管理。這樣,用戶就可以用autowair注入所有實現。而實際上我們的代理proxy就成了所有接口的實現。
  • 用戶調用任何接口時,都調用了我們生成的bean實現。其實都進入了我們相同的handler實現,實現中我們可以知道用戶想要調用的完整方法名稱(從它的目錄路徑可以分析出目標應用名)、參數。然后序列化后去遠端調用并返回結果即可。

3 動態代理

cglib是通過字節碼,生成了目標類的子類實現動態代理的。因此,對于final的方法無法使用cglib進行動態代理。

首先引入Cglib包:

遠程過程調用RPC的實現原理:動態代理

首先,目標對象不發生任何變化,并且該類也不需要實現任何接口了:

遠程過程調用RPC的實現原理:動態代理

代理類寫法如下:

遠程過程調用RPC的實現原理:動態代理

通過代碼我們也可以看出,代理類是作為目標類的子類出現的,在調用目標類方法時,實際是調用父類。

使用如下:

遠程過程調用RPC的實現原理:動態代理

使用過程比較簡單:

1. 生成一個代理對象

2. 告訴代理對象,它的實現在哪里

3. 告訴代理對象,它的父類是誰

4. 生成代理類的對象

5. 調用代理對象的方法

這樣,對生成的代理對象進行調用時,會調用到它的回調對象,然后回調對象中根據操作可能調用目標對象(父類)的方法。

得到結果:

before speak

hello Jack

after speak

OK

分享到:
標簽:RPC
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定