日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

一文告诉你 Java RMI 和 RPC 的区别

發(fā)布時間:2023/12/3 java 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 一文告诉你 Java RMI 和 RPC 的区别 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

轉(zhuǎn)載自??一文告訴你 Java RMI 和 RPC 的區(qū)別

RPC 遠(yuǎn)程過程調(diào)用

RPC(Remote Procedure Call Protocol)遠(yuǎn)程過程調(diào)用協(xié)議,通過網(wǎng)絡(luò)從遠(yuǎn)程計(jì)算機(jī)上請求調(diào)用某種服務(wù)。一次RPC調(diào)用的過程大概有10步:

1.執(zhí)行客戶端調(diào)用語句,傳送參數(shù)

2.調(diào)用本地系統(tǒng)發(fā)送網(wǎng)絡(luò)消息

3.消息傳送到遠(yuǎn)程主機(jī)

4.服務(wù)器得到消息并取得參數(shù)?

5.根據(jù)調(diào)用請求以及參數(shù)執(zhí)行遠(yuǎn)程過程(服務(wù))

6.執(zhí)行過程完畢,將結(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)用語句返回的結(jié)果數(shù)據(jù)

?

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

RMI:遠(yuǎn)程方法調(diào)用(Remote Method Invocation)。能夠讓在客戶端Java虛擬機(jī)上的對象像調(diào)用本地對象一樣調(diào)用服務(wù)端java 虛擬機(jī)中的對象上的方法。點(diǎn)擊這里查看Dubbo架構(gòu)詳解。

?

?

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

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

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

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

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

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

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

7,客戶獲得返回值

?

RPC 與 RMI 的區(qū)別

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

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

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

?

2:適用語言范圍不同

RMI只用于Java;

RPC是網(wǎng)絡(luò)服務(wù)協(xié)議,與操作系統(tǒng)和語言無關(guān)。

?

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

Java是面向?qū)ο蟮?#xff0c;所以RMI的調(diào)用結(jié)果可以是對象類型或者基本數(shù)據(jù)類型;

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

來源:www.cnblogs.com/ygj0930/p/6542811.html

?

總結(jié)

以上是生活随笔為你收集整理的一文告诉你 Java RMI 和 RPC 的区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。