一文告诉你 Java RMI 和 RPC 的区别
轉(zhuǎn)載自??一文告訴你 Java RMI 和 RPC 的區(qū)別
RPC 遠程過程調(diào)用
RPC(Remote Procedure Call Protocol)遠程過程調(diào)用協(xié)議,通過網(wǎng)絡從遠程計算機上請求調(diào)用某種服務。一次RPC調(diào)用的過程大概有10步:
1.執(zhí)行客戶端調(diào)用語句,傳送參數(shù)
2.調(diào)用本地系統(tǒng)發(fā)送網(wǎng)絡消息
3.消息傳送到遠程主機
4.服務器得到消息并取得參數(shù)?
5.根據(jù)調(diào)用請求以及參數(shù)執(zhí)行遠程過程(服務)
6.執(zhí)行過程完畢,將結果返回服務器句柄
7.服務器句柄返回結果,調(diào)用遠程主機的系統(tǒng)網(wǎng)絡服務發(fā)送結果
8.消息傳回本地主機?
9.客戶端句柄由本地主機的網(wǎng)絡服務接收消息
10.客戶端接收到調(diào)用語句返回的結果數(shù)據(jù)
?
RMI 遠程方法調(diào)用
RMI:遠程方法調(diào)用(Remote Method Invocation)。能夠讓在客戶端Java虛擬機上的對象像調(diào)用本地對象一樣調(diào)用服務端java 虛擬機中的對象上的方法。點擊這里查看Dubbo架構詳解。
?
?
RMI遠程調(diào)用步驟:
1,客戶調(diào)用客戶端輔助對象stub上的方法
2,客戶端輔助對象stub打包調(diào)用信息(變量,方法名),通過網(wǎng)絡發(fā)送給服務端輔助對象skeleton
3,服務端輔助對象skeleton將客戶端輔助對象發(fā)送來的信息解包,找出真正被調(diào)用的方法以及該方法所在對象
4,調(diào)用真正服務對象上的真正方法,并將結果返回給服務端輔助對象skeleton
5,服務端輔助對象將結果打包,發(fā)送給客戶端輔助對象stub
6,客戶端輔助對象將返回值解包,返回給調(diào)用者
7,客戶獲得返回值
?
RPC 與 RMI 的區(qū)別
1:方法調(diào)用方式不同
RMI中是通過在客戶端的Stub對象作為遠程接口進行遠程方法的調(diào)用。每個遠程方法都具有方法簽名。如果一個方法在服務器上執(zhí)行,但是沒有相匹配的簽名被添加到這個遠程接口(stub)上,那么這個新方法就不能被RMI客戶方所調(diào)用。點擊這里查看Dubbo架構詳解。
RPC中是通過網(wǎng)絡服務協(xié)議向遠程主機發(fā)送請求,請求包含了一個參數(shù)集和一個文本值,通常形成“classname.methodname(參數(shù)集)”的形式。RPC遠程主機就去搜索與之相匹配的類和方法,找到后就執(zhí)行方法并把結果編碼,通過網(wǎng)絡協(xié)議發(fā)回。
?
2:適用語言范圍不同
RMI只用于Java;
RPC是網(wǎng)絡服務協(xié)議,與操作系統(tǒng)和語言無關。
?
3:調(diào)用結果的返回形式不同
Java是面向?qū)ο蟮?#xff0c;所以RMI的調(diào)用結果可以是對象類型或者基本數(shù)據(jù)類型;
RMI的結果統(tǒng)一由外部數(shù)據(jù)表示 (External Data Representation, XDR) 語言表示,這種語言抽象了字節(jié)序類和數(shù)據(jù)類型結構之間的差異。
來源:www.cnblogs.com/ygj0930/p/6542811.html
?
總結
以上是生活随笔為你收集整理的一文告诉你 Java RMI 和 RPC 的区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SSL / TLS 协议运行机制详解
- 下一篇: Java架构师必须知道的 6 大设计原则