總結(jié):詳解RMI與RPC的區(qū)別

RPC(遠(yuǎn)程過(guò)程調(diào)用)和RMI(遠(yuǎn)程方法調(diào)用)是兩種可以讓用戶(hù)從一臺(tái)電腦調(diào)用不同電腦上面的方法的的機(jī)制(也可以稱(chēng)作規(guī)范、協(xié)議)。兩者的主要不同是他們的使用方式或者稱(chēng)作范式,RMI使用面向?qū)ο蟮姆妒剑簿褪怯脩?hù)需要知道他調(diào)用的對(duì)象和對(duì)象中的方法;RPC不是面向?qū)ο笠膊荒芴幚韺?duì)象,而是調(diào)用具體的子程序。

一:RPC 遠(yuǎn)程過(guò)程調(diào)用

RPC(Remote Procedure Call Protocol)遠(yuǎn)程過(guò)程調(diào)用協(xié)議,通過(guò)網(wǎng)絡(luò)從遠(yuǎn)程計(jì)算機(jī)上請(qǐng)求調(diào)用某種服務(wù)。

一次RPC調(diào)用的過(guò)程大概有10步

1、執(zhí)行客戶(hù)端調(diào)用語(yǔ)句,傳送參數(shù)
2、調(diào)用本地系統(tǒng)發(fā)送網(wǎng)絡(luò)消息
3、消息傳送到遠(yuǎn)程主機(jī)
4、服務(wù)器得到消息并取得參數(shù)
5、根據(jù)調(diào)用請(qǐng)求以及參數(shù)執(zhí)行遠(yuǎn)程過(guò)程(服務(wù))
6、執(zhí)行過(guò)程完畢,將結(jié)果返回服務(wù)器句柄
7、服務(wù)器句柄返回結(jié)果,調(diào)用遠(yuǎn)程主機(jī)的系統(tǒng)網(wǎng)絡(luò)服務(wù)發(fā)送結(jié)果
8、消息傳回本地主機(jī)
9、客戶(hù)端句柄由本地主機(jī)的網(wǎng)絡(luò)服務(wù)接收消息
10、客戶(hù)端接收到調(diào)用語(yǔ)句返回的結(jié)果數(shù)據(jù)

二:RMI 遠(yuǎn)程方法調(diào)用
RMI:遠(yuǎn)程方法調(diào)用(Remote Method Invocation)。能夠讓在客戶(hù)端Java虛擬機(jī)上的對(duì)象像調(diào)用本地對(duì)象一樣調(diào)用服務(wù)端Java虛擬機(jī)中的對(duì)象上的方法。


圖片.png

RMI遠(yuǎn)程調(diào)用步驟:
1、客戶(hù)調(diào)用客戶(hù)端輔助對(duì)象stub上的方法
2、客戶(hù)端輔助對(duì)象stub打包調(diào)用信息(變量,方法名),通過(guò)網(wǎng)絡(luò)發(fā)送給服務(wù)端輔助對(duì)象skeleton
3、服務(wù)端輔助對(duì)象skeleton將客戶(hù)端輔助對(duì)象發(fā)送來(lái)的信息解包,找出真正被調(diào)用的方法以及該方法所在對(duì)象
4、調(diào)用真正服務(wù)對(duì)象上的真正方法,并將結(jié)果返回給服務(wù)端輔助對(duì)象skeleton
5、服務(wù)端輔助對(duì)象將結(jié)果打包,發(fā)送給客戶(hù)端輔助對(duì)象stub
6、客戶(hù)端輔助對(duì)象將返回值解包,返回給調(diào)用者
7、客戶(hù)獲得返回值

三:RPC與RMI的區(qū)別

1:方法調(diào)用方式不同:

RMI中是通過(guò)在客戶(hù)端的Stub對(duì)象作為遠(yuǎn)程接口進(jìn)行遠(yuǎn)程方法的調(diào)用。每個(gè)遠(yuǎn)程方法都具有方法簽名。如果一個(gè)方法在服務(wù)器上執(zhí)行,但是沒(méi)有相匹配的簽名被添加到這個(gè)遠(yuǎn)程接口(stub)上,那么這個(gè)新方法就不能被RMI客戶(hù)方所調(diào)用。

RPC中是通過(guò)網(wǎng)絡(luò)服務(wù)協(xié)議向遠(yuǎn)程主機(jī)發(fā)送請(qǐng)求,請(qǐng)求包含了一個(gè)參數(shù)集和一個(gè)文本值,通常形成“classname.methodname(參數(shù)集)”的形式。RPC遠(yuǎn)程主機(jī)就去搜索與之相匹配的類(lèi)和方法,找到后就執(zhí)行方法并把結(jié)果編碼,通過(guò)網(wǎng)絡(luò)協(xié)議發(fā)回。

2:適用語(yǔ)言范圍不同:

RMI只用于Java;RPC是網(wǎng)絡(luò)服務(wù)協(xié)議,與操作系統(tǒng)和語(yǔ)言無(wú)關(guān)。

3:調(diào)用結(jié)果的返回形式不同:

Java是面向?qū)ο蟮?,所以RMI的調(diào)用結(jié)果可以是對(duì)象類(lèi)型或者基本數(shù)據(jù)類(lèi)型;RMI的結(jié)果統(tǒng)一由外部數(shù)據(jù)表示,這種語(yǔ)言抽象了字節(jié)序類(lèi)和數(shù)據(jù)類(lèi)型結(jié)構(gòu)之間的差異。

轉(zhuǎn)自:https://zhuanlan.zhihu.com/p/50678735

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • RPC 遠(yuǎn)程過(guò)程調(diào)用 RPC(Remote Procedure Call Protocol)遠(yuǎn)程過(guò)程調(diào)用協(xié)議,通過(guò)...
    Java高級(jí)架構(gòu)獅閱讀 962評(píng)論 0 1
  • 一:RPC 遠(yuǎn)程過(guò)程調(diào)用 RPC(Remote Procedure Call Protocol)遠(yuǎn)程過(guò)程調(diào)用協(xié)議,...
    03ca2835cf70閱讀 41評(píng)論 0 0
  • 首先介紹一下兩者 RMI(Remote Method Invocation)遠(yuǎn)程方法調(diào)用, 支持存儲(chǔ)于不同地址空間...
    Azkaban閱讀 766評(píng)論 0 1
  • 表情是什么,我認(rèn)為表情就是表現(xiàn)出來(lái)的情緒。表情可以傳達(dá)很多信息。高興了當(dāng)然就笑了,難過(guò)就哭了。兩者是相互影響密不可...
    Persistenc_6aea閱讀 129,700評(píng)論 2 7
  • 16宿命:用概率思維提高你的勝算 以前的我是風(fēng)險(xiǎn)厭惡者,不喜歡去冒險(xiǎn),但是人生放棄了冒險(xiǎn),也就放棄了無(wú)數(shù)的可能。 ...
    yichen大刀閱讀 7,882評(píng)論 0 4

友情鏈接更多精彩內(nèi)容