真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

好程序員Java培訓(xùn)分享之RMI與RPC的區(qū)別

 好程序員Java培訓(xùn)分享 之RMI與RPC的區(qū)別, 隨著java技術(shù)學(xué)習(xí)的不斷深入,越來(lái)越覺得保持初心是多么重要,無(wú)論我們學(xué)到哪個(gè)程度,在學(xué)習(xí)的時(shí)候始終保持初學(xué)者的心態(tài),才能在自己的技術(shù)之上實(shí)現(xiàn)突破!

創(chuàng)新互聯(lián)是一家專注于網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),七星關(guān)區(qū)網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十載,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:七星關(guān)區(qū)等地區(qū)。七星關(guān)區(qū)做網(wǎng)站價(jià)格咨詢:18982081108

  今天有點(diǎn)像雞湯,回歸正題,繼續(xù)更新我的學(xué)習(xí)筆記:Java技術(shù)中的 RMI與RPC的區(qū)別。

一: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í)行客戶端調(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.客戶端句柄由本地主機(jī)的網(wǎng)絡(luò)服務(wù)接收消息

10.客戶端接收到調(diào)用語(yǔ)句返回的結(jié)果數(shù)據(jù)

二:RMI 遠(yuǎn)程方法調(diào)用

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

好程序員Java培訓(xùn)分享之RMI與RPC的區(qū)別

RMI遠(yuǎn)程調(diào)用步驟:

1,客戶調(diào)用客戶端輔助對(duì)象stub上的方法

2,客戶端輔助對(duì)象stub打包調(diào)用信息(變量,方法名),通過(guò)網(wǎng)絡(luò)發(fā)送給服務(wù)端輔助對(duì)象skeleton

3,服務(wù)端輔助對(duì)象skeleton將客戶端輔助對(duì)象發(fā)送來(lái)的信息解包,找出真正被調(diào)用的方法以及該方法所在對(duì)象

4,調(diào)用真正服務(wù)對(duì)象上的真正方法,并將結(jié)果返回給服務(wù)端輔助對(duì)象skeleton

5,服務(wù)端輔助對(duì)象將結(jié)果打包,發(fā)送給客戶端輔助對(duì)象stub

6,客戶端輔助對(duì)象將返回值解包,返回給調(diào)用者

7,客戶獲得返回值

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

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

RMI中是通過(guò)在客戶端的Stub對(duì)象作為遠(yuǎn)程接口進(jìn)行遠(yuǎn)程方法的調(diào)用。每個(gè)遠(yuǎn)程方法都具有方法簽名。如果一個(gè)方法在服務(wù)器上執(zhí)行,但是沒有相匹配的簽名被添加到這個(gè)遠(yuǎn)程接口(stub)上,那么這個(gè)新方法就不能被RMI客戶方所調(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ī)就去搜索與之相匹配的類和方法,找到后就執(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ì)象類型或者基本數(shù)據(jù)類型;

RMI的結(jié)果統(tǒng)一由外部數(shù)據(jù)表示 (External Data Representation, XDR) 語(yǔ)言表示,這種語(yǔ)言抽象了字節(jié)序類和數(shù)據(jù)類型結(jié)構(gòu)之間的差異。


本文標(biāo)題:好程序員Java培訓(xùn)分享之RMI與RPC的區(qū)別
網(wǎng)頁(yè)網(wǎng)址:http://weahome.cn/article/ggeoii.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部