大白話談談RPC

好久沒有更新了哇
首先說RPC之前购岗,需要先了解RPC是什么,RPC的工作原理是什么门粪,這才能做到心中有數(shù)喊积。

RPC的全稱是Remote Procedure Call,遠程方法調用玄妈。它是發(fā)生于兩個進程之間乾吻,

一個服務端髓梅,一個客戶端。服務端提供服務溶弟,客戶端請求服務端女淑。簡單點理解呢瞭郑,像HTTP請求

一樣辜御,發(fā)起一個請求,然后就返回一個結果屈张。而RPC呢擒权,只不過是在本地調用遠程的一個方法,然后遠程

返回一個結果阁谆。照著自己的思路把這個過程寫下來碳抄。

  1. 服務端和客戶端之間要通信,那就不可避免的需要網(wǎng)絡通信场绿∑市В客戶端與服務端需要建立網(wǎng)絡連接

(可以用Netty作為網(wǎng)絡通訊的框架)

  1. 接下來,調用一個方法焰盗,服務端需要知道哪些數(shù)據(jù)璧尸。作為服務端需要知道你要調用哪個對象的哪個方法,有哪些參數(shù)熬拒,而這些數(shù)據(jù)則需要客戶端通過網(wǎng)絡傳輸給服務端爷光。這個過程就涉及到編解碼,需要定義自己的編碼器和解碼器(可以用阿里的fastjaon, google的protobuff等等)澎粟。
  2. 最后蛀序,客戶端的操作希望是在本地調用自己的方法一樣,但本地是沒有這些方法的實現(xiàn)的活烙,所以需要用代理對象去調用徐裸,當代理對象調用這個方法時,則對應向服務端發(fā)起一個請求啸盏,然后等待服務器的結果返回倦逐。這個過程就需要用到jdk或者cglib的動態(tài)代理

總結一下上面的流程

客戶端調用方法 --> 代理對象封裝參數(shù)宫补,向服務端請求(等待結果返回) --> 服務端收到請求檬姥,調用對應方法,將結果返回給客戶端

流程圖

當然粉怕,上面只是最簡單的流程健民,RPC的實現(xiàn)還有一些細節(jié)。

比如贫贝,客戶端怎么知道服務端的這些服務呢秉犹,可以采用Zookeeper等注冊中心將服務注冊蛉谜,讓客戶端可以自動發(fā)現(xiàn)。再比如崇堵,需要監(jiān)控這些服務的調用數(shù)據(jù)等型诚,可以增加監(jiān)控系統(tǒng)。很多細節(jié)都可以慢慢琢磨鸳劳。

如果錯誤的地方狰贯,請糾正,大家一起學習進步赏廓。

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末涵紊,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子幔摸,更是在濱河造成了極大的恐慌摸柄,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件既忆,死亡現(xiàn)場離奇詭異驱负,居然都是意外死亡,警方通過查閱死者的電腦和手機患雇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門跃脊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人庆亡,你說我怎么就攤上這事匾乓。” “怎么了又谋?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵拼缝,是天一觀的道長。 經(jīng)常有香客問我彰亥,道長咧七,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任任斋,我火速辦了婚禮继阻,結果婚禮上,老公的妹妹穿的比我還像新娘废酷。我一直安慰自己瘟檩,他們只是感情好,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布澈蟆。 她就那樣靜靜地躺著墨辛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪趴俘。 梳的紋絲不亂的頭發(fā)上睹簇,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天奏赘,我揣著相機與錄音,去河邊找鬼太惠。 笑死磨淌,一個胖子當著我的面吹牛,可吹牛的內容都是我干的凿渊。 我是一名探鬼主播梁只,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼嗽元!你這毒婦竟也來了敛纲?” 一聲冷哼從身側響起喂击,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤剂癌,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后翰绊,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體佩谷,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年监嗜,在試婚紗的時候發(fā)現(xiàn)自己被綠了谐檀。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡裁奇,死狀恐怖桐猬,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情刽肠,我是刑警寧澤溃肪,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站音五,受9級特大地震影響惫撰,放射性物質發(fā)生泄漏。R本人自食惡果不足惜躺涝,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一厨钻、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧坚嗜,春花似錦夯膀、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至银室,卻和暖如春涂佃,著一層夾襖步出監(jiān)牢的瞬間励翼,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工辜荠, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留汽抚,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓伯病,卻偏偏與公主長得像造烁,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子午笛,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345