Java RMI與RPC的區別

轉載請註明原文地址:http://www.cnblogs.com/ygj0930/p/6542811.html html

 一:RPC 遠程過程調用java

 RPC(Remote Procedure Call Protocol)遠程過程調用協議,經過網絡從遠程計算機上請求調用某種服務。服務器

 一次RPC調用的過程大概有10步:網絡

  1.執行客戶端調用語句,傳送參數編碼

  2.調用本地系統發送網絡消息spa

  3.消息傳送到遠程主機操作系統

  4.服務器獲得消息並取得參數 htm

  5.根據調用請求以及參數執行遠程過程(服務)對象

  6.執行過程完畢,將結果返回服務器句柄blog

  7.服務器句柄返回結果,調用遠程主機的系統網絡服務發送結果

  8.消息傳回本地主機 

  9.客戶端句柄由本地主機的網絡服務接收消息

  10.客戶端接收到調用語句返回的結果數據

 

 二:RMI 遠程方法調用

 RMI:遠程方法調用(Remote Method Invocation)。可以讓在客戶端Java虛擬機上的對象像調用本地對象同樣調用服務端java 虛擬機中的對象上的方法。

RMI遠程調用步驟:

1,客戶調用客戶端輔助對象stub上的方法

2,客戶端輔助對象stub打包調用信息(變量,方法名),經過網絡發送給服務端輔助對象skeleton

3,服務端輔助對象skeleton將客戶端輔助對象發送來的信息解包,找出真正被調用的方法以及該方法所在對象

4,調用真正服務對象上的真正方法,並將結果返回給服務端輔助對象skeleton

5,服務端輔助對象將結果打包,發送給客戶端輔助對象stub

6,客戶端輔助對象將返回值解包,返回給調用者

7,客戶得到返回值

 

 三:RPC與RMI的區別

 1:方法調用方式不一樣:

 RMI中是經過在客戶端的Stub對象做爲遠程接口進行遠程方法的調用每一個遠程方法都具備方法簽名。若是一個方法在服務器上執行,可是沒有相匹配的簽名被添加到這個遠程接口(stub)上,那麼這個新方法就不能被RMI客戶方所調用

 

  RPC中是經過網絡服務協議向遠程主機發送請求,請求包含了一個參數集和一個文本值,一般造成「classname.methodname(參數集)」的形式。RPC遠程主機就去搜索與之相匹配的類和方法,找到後就執行方法並把結果編碼,經過網絡協議發回。

 

  2:適用語言範圍不一樣:

   RMI只用於Java;

   RPC是網絡服務協議,與操做系統和語言無關。

 

  3:調用結果的返回形式不一樣:

    Java是面向對象的,因此RMI的調用結果能夠是對象類型或者基本數據類型;

    RMI的結果統一由外部數據表示 (External Data Representation, XDR) 語言表示,這種語言抽象了字節序類和數據類型結構之間的差別。

相關文章
相關標籤/搜索