RPC,全稱 Remote Procedure Call(遠(yuǎn)程過程調(diào)用),即調(diào)用遠(yuǎn)程計算機(jī)上的服務(wù),就像調(diào)用本地服務(wù)一樣。那么RPC的原理是什么呢?了解一個技術(shù)最好的思路就是尋找一個該類型麻雀雖小五臟俱全的開源項目,不負(fù)所期,找到一個輕量級分布式 RPC 框架,本文從這個項目入手來解讀RPC的原理及其實現(xiàn)。

其實說到RPC,大家應(yīng)該不會陌生才是,以往流行的Web Service就是一種RPC,一般來說RPC 可基于 HTTP 或 TCP 協(xié)議,因為Web Service 基于HTTP,所以具有良好的跨平臺性,但由于HTTP是應(yīng)用層協(xié)議,相比TCP性能有所損耗。

與本地調(diào)用不一樣,遠(yuǎn)程調(diào)用需要通過網(wǎng)絡(luò)層傳輸,因此涉及到的一個問題就是序列化,不同的序列化方式影響調(diào)用性能,流行的序列化包括Protobuf、Kryo、Hessian、Jackson、Thrift。

下面,讓我們來一關(guān)如何從零開始實現(xiàn)分布式RPC框架。

RPC框架組件

建設(shè)一個框架,一個系統(tǒng),首先要做的就是分析需要哪些組件,他們的關(guān)系是什么?

簡單分析下,一個RPC框架需要包括:

  • APP :應(yīng)用端,調(diào)用服務(wù)

  • Server 服務(wù)容器,對外提供服務(wù)

  • Service Registry 服務(wù)注冊表

網(wǎng)友評論