国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Java學(xué)習(xí)筆記之RMI與RPC的區(qū)別

Java學(xué)習(xí)筆記之RMI與RPC的區(qū)別

來(lái)源:千鋒教育
發(fā)布人:千鋒老師
時(shí)間: 2018-11-28 11:17:00 1543375020

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

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

圖片1

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

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

圖片2

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

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

圖片3

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

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

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

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

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

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

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

  7,客戶(hù)獲得返回值

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

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

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

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

  學(xué)習(xí)java開(kāi)發(fā),可以參考千鋒提供的java學(xué)習(xí)路線(xiàn),該學(xué)習(xí)路線(xiàn)羅列了各階段完整的java學(xué)習(xí)知識(shí),根據(jù)千鋒提供的java學(xué)習(xí)路線(xiàn)圖,可以讓你對(duì)學(xué)好java開(kāi)發(fā)需要掌握的知識(shí)有個(gè)清晰的了解,并能快速入門(mén)java開(kāi)發(fā)。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
云原生存儲(chǔ)和云存儲(chǔ)有什么區(qū)別?

一、架構(gòu)設(shè)計(jì)不同云原生存儲(chǔ)是指在云原生環(huán)境下設(shè)計(jì)和構(gòu)建的存儲(chǔ)系統(tǒng)。它是基于云原生計(jì)算模式和原則進(jìn)行設(shè)計(jì),充分利用容器、微服務(wù)和自動(dòng)化管...詳情>>

2023-10-14 06:50:34
如何刪除需要使用管理員權(quán)限才能刪除的文件?

如何刪除需要使用管理員權(quán)限才能刪除的文件在Windows系統(tǒng)中,有時(shí)候我們可能會(huì)遇到一些需要管理員權(quán)限才能刪除的文件。這是因?yàn)檫@些文件可能是...詳情>>

2023-10-14 06:27:57
有什么好用的redis可視化管理工具?

一、Redis Desk較好 ManagerRedis Desk較好 Manager是一款非常受歡迎的Redis數(shù)據(jù)庫(kù)管理工具。它支持直接進(jìn)行數(shù)據(jù)修改、刪除和新增等操作,而且...詳情>>

2023-10-14 06:24:43
市場(chǎng)上C++主要是用來(lái)做什么的?

C++是一種廣泛應(yīng)用于市場(chǎng)上的編程語(yǔ)言,具有高性能和強(qiáng)大的功能。它的設(shè)計(jì)目標(biāo)是提供高效的底層控制和與硬件交互的能力,同時(shí)保持可移植性和可...詳情>>

2023-10-14 06:01:51
為什么說(shuō)PHP與Swoole是優(yōu)異組合?

PHP與Swoole在Web開(kāi)發(fā)和網(wǎng)絡(luò)編程領(lǐng)域中,共同構(gòu)成了一種強(qiáng)大的解決方案。什么是PHPPHP是一種廣泛使用的開(kāi)源服務(wù)器端腳本語(yǔ)言,特別適用于Web開(kāi)...詳情>>

2023-10-14 05:08:41
快速通道