欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

RPC、RMI、SOAP的區(qū)別詳解

 更新時間:2015年07月06日 10:20:28   投稿:junjie  
這篇文章主要介紹了RPC、RMI、SOAP的區(qū)別詳解,本文還同時講解了RPC、SOAP、WSDL的關系,需要的朋友可以參考下

============================================================================
RPC與RMI的區(qū)別
============================================================================
RPC:(Remote Procedure Call)
  被設計為在應用程序間通信的平臺中立的方式,它不理會操作系統(tǒng)之間以及語言之間的差異。 支持多語言。

RMI:(Remote Method Invocation)
RPC 的Java版本,EJB的基礎技術(shù)
RMI 采用JRMP(Java Remote Method Protocol)通訊協(xié)議,是構(gòu)建在TCP/IP協(xié)議上的一種遠程調(diào)用方法。
RMI 采用stubs和skeletons來進行遠程對象的通訊。
  stub充當遠程對象的客戶端代理,有著和遠程對象相同的遠程接口。
  遠程對象的調(diào)用實際是通過調(diào)用該對象的客戶端代理對象stub來完成的。

    創(chuàng)建遠程方法調(diào)用的5個步驟:
    1)定義一個擴展了Remote接口的接口,該接口中的每一個方法必須聲明它將產(chǎn)生一個RemoteException異常;
    2)定義一個實現(xiàn)該接口的類;
    3)使用rmic程序生成遠程實現(xiàn)所需的存根和框架;
      (例如,在demo.rmi.EchoServer.java所在目錄運行: rmic demo.rmi.EchoServer)
    4)創(chuàng)建一個客戶程序和服務器進行RMI調(diào)用;
    5)啟動rmiregistry并運行自己的服務程序和客戶程序。

RMI與RPC的區(qū)別在于:
1)方法是如何被調(diào)用的
  對RMI來說,如果一個方法在服務器上執(zhí)行,但是沒有相匹配的簽名被添加到這個遠程接口上,那么這個新方法就不能被RMI客戶方所調(diào)用。
  而在RPC中,當一個請求到達RPC服務器時,請求包含一個參數(shù)集和一個文本值,通常為“classname.methodname”形式。
  這表明,請求的方法在“classname”類中,名叫“methodname”。
  然后,RPC服務器就去搜索與之相匹配的類和方法,并把它作為那種方法參數(shù)類型的輸入。
  這里的參數(shù)類型是與RPC請求中的類型匹配的。 一旦匹配成功,方法就被調(diào)用了,其結(jié)果被編碼后返回客戶方。
2)對傳遞信息的限制
  RMI 調(diào)用遠程對象方法,允許方法返回 Java 對象以及基本數(shù)據(jù)類型。
  而RPC不允許傳遞對象,RPC服務的消息由外部數(shù)據(jù)表示(External Data Representation,XDR)語言來表示。
3)采用的協(xié)議不同
    RPC不支持對象,采用http協(xié)議。RMI支持傳輸對象,采用TCP/IP協(xié)議
4)RIM只限于Java語言,而RPC跨語言
   
另外,RMI優(yōu)于RPC或SOAP的一點是:在程序開發(fā)過程中因為對象或方法不匹配造成的錯誤可以在編譯期被發(fā)現(xiàn),而不用等到運行期。

============================================================================
RPC, SOAP, WSDL的關系
============================================================================
RPC, SOAP, WSDL都是web service的關鍵詞,這里描述一下他們的關系,下面的解釋可能比較狹義,主要為了幫助理解這三者的關系。
 
1.RPC

如果要調(diào)用遠端的一個方法,可以使用RMI和RPC,這是2種截然不同的風格。
RMI: (Remote Method Invocation) 直接獲取遠端方法的簽名,進行調(diào)用。優(yōu)點是強類型、編譯期可檢查錯誤;缺點是只限于java語言
RPC: (Remote Procedure Call) 采用客戶端/服務器方式(請求/響應),發(fā)送請求到服務器端,服務端執(zhí)行方法后返回結(jié)果。優(yōu)點是跨語言跨平臺,缺點是編譯期無法排錯,只能在運行時檢查。
 
2.SOAP

為了包裝RPC的請求信息,推出了XML-RPC,但XML-RPC只能使用有限的數(shù)據(jù)類型種類和一些簡單的數(shù)據(jù)結(jié)構(gòu)。于是就出現(xiàn)了SOAP(Simple Object Access Protocol)。SOAP最主要的工作是使用標準的XML描述了RPC的請求信息(URI/類/方法/參數(shù)/返回值)。理論上,SOAP就是一段xml,你可以通過http,smtp等發(fā)送它(復制到軟盤上,叫快遞公司送去也行?)。同樣SOAP也是跨語言的。
 
3.WSDL

WSDL(Web Services Description Language)是描述web服務的,是描述怎樣訪問web服務的。WSDL是用來描述SOAP的,換句話說,WSDL 文件告訴你調(diào)用 SOAP 所需要知道的一切。WSDL也是一段xml。現(xiàn)在各個語言對wsdl的支持都很成熟,可以根據(jù)同一份wsdl文件生成自己語言的客戶端。

相關文章

  • BurpSuite超詳細安裝和基礎使用教程(已破解)

    BurpSuite超詳細安裝和基礎使用教程(已破解)

    Burp?Suite?是用于攻擊web?應用程序的集成平臺包含了許多Burp工具,它主要用來做安全性滲透測試,可以實現(xiàn)攔截請求、Burp?Spider爬蟲、漏洞掃描(付費)等類似Fiddler和Postman但比其更強大的功能,今天給大家介紹下BurpSuite安裝破解使用教程,感興趣的朋友一起看看吧
    2022-10-10
  • 聯(lián)邦學習論文解讀分散數(shù)據(jù)的深層網(wǎng)絡通信

    聯(lián)邦學習論文解讀分散數(shù)據(jù)的深層網(wǎng)絡通信

    這篇文章主要為大家介紹了論文解讀分散數(shù)據(jù)的深層網(wǎng)絡通信有效學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • 解讀Base64編碼中為什么會有等號(=)問題

    解讀Base64編碼中為什么會有等號(=)問題

    這篇文章主要介紹了解讀Base64編碼中為什么會有等號(=)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 詳解git submodule HEAD detached 的問題

    詳解git submodule HEAD detached 的問題

    這篇文章主要介紹了詳解git submodule HEAD detached 的問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • 什么是gRPC

    什么是gRPC

    本文主要介紹了什么是gRPC,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • 詳細講解HDFS的高可用機制

    詳細講解HDFS的高可用機制

    本文詳細講解了HDFS的高可用機制。如果namenode出現(xiàn)問題,整個HDFS集群將不能使用,HDFS高可用(HA)方案就是為了解決這個問題而產(chǎn)生的,讓我們一起來了解了解吧
    2021-08-08
  • 如果你有這33種癥狀了請離開電腦去走走吧!

    如果你有這33種癥狀了請離開電腦去走走吧!

    這篇文章主要介紹了如果你有這33種癥狀了請離開電腦去走走吧!本文是關注程序員、上班族身心健康的文章,需要的朋友可以參考下
    2014-09-09
  • asp.net php asp jsp 301重定向的代碼(集合)

    asp.net php asp jsp 301重定向的代碼(集合)

    介紹一下針對各類程序系統(tǒng)實施301重定向的代碼,需要的朋友可以參考下。
    2010-11-11
  • qqwry.dat的數(shù)據(jù)結(jié)構(gòu)圖文解釋

    qqwry.dat的數(shù)據(jù)結(jié)構(gòu)圖文解釋

    QQwry.dat可以看作是一種數(shù)據(jù)文件,通過它能完成以下任務
    2009-02-02
  • vscode安裝使用的詳細教程

    vscode安裝使用的詳細教程

    Visual Studio Code (簡稱 VS Code / VSC) 是一款免費開源的現(xiàn)代化輕量級代碼編輯器,這篇文章主要介紹了vscode安裝使用的詳細教程,需要的朋友可以參考下
    2020-08-08

最新評論