RPC,全稱 Remote Procedure Call(遠(yuǎn)程過(guò)程調(diào)用),即調(diào)用遠(yuǎn)程計(jì)算機(jī)上的服務(wù),就像調(diào)用本地服務(wù)一樣。那么RPC的原理是什么呢?了解一個(gè)技術(shù)最好的思路就是尋找一個(gè)該類型麻雀雖小五臟俱全的開(kāi)源項(xiàng)目,不負(fù)所期,找到一個(gè)輕量級(jí)分布式 RPC 框架,本文從這個(gè)項(xiàng)目入手來(lái)解讀RPC的原理及其實(shí)現(xiàn)。
其實(shí)說(shuō)到RPC,大家應(yīng)該不會(huì)陌生才是,以往流行的Web Service就是一種RPC,一般來(lái)說(shuō)RPC 可基于 HTTP 或 TCP 協(xié)議,因?yàn)閃eb Service 基于HTTP,所以具有良好的跨平臺(tái)性,但由于HTTP是應(yīng)用層協(xié)議,相比TCP性能有所損耗。
與本地調(diào)用不一樣,遠(yuǎn)程調(diào)用需要通過(guò)網(wǎng)絡(luò)層傳輸,因此涉及到的一個(gè)問(wèn)題就是序列化,不同的序列化方式影響調(diào)用性能,流行的序列化包括Protobuf、Kryo、Hessian、Jackson、Thrift。
下面,讓我們來(lái)一關(guān)如何從零開(kāi)始實(shí)現(xiàn)分布式RPC框架。
RPC框架組件
建設(shè)一個(gè)框架,一個(gè)系統(tǒng),首先要做的就是分析需要哪些組件,他們的關(guān)系是什么?
簡(jiǎn)單分析下,一個(gè)RPC框架需要包括:
APP :應(yīng)用端,調(diào)用服務(wù)
Server 服務(wù)容器,對(duì)外提供服務(wù)
Service Registry 服務(wù)注冊(cè)表
延伸閱讀
學(xué)習(xí)是年輕人改變自己的最好方式
- ssh框架 2016-09-30
- 阿里移動(dòng)安全 [無(wú)線安全]玩轉(zhuǎn)無(wú)線電——不安全的藍(lán)牙鎖 2017-07-26
- 消息隊(duì)列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標(biāo)分割】 2017-07-26
- 詞向量-LRWE模型-更好地識(shí)別反義詞同義詞 2017-07-26
- 從棧不平衡問(wèn)題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實(shí)現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動(dòng)安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來(lái)看看(二) 2017-07-26