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