RPC,即 Remote Procedure Call(遠程過程調用),說得通俗一點就是:調用遠程計算機上的服務,就像調用本地服務一樣。

我所在公司的項目是采用基于Restful的微服務架構,隨著微服務之間的溝通越來越頻繁,就希望可以做成用rpc來做內部的通訊,對外依然用Restful。于是就想到了golang標準庫的rpc包和google的grpc。

這篇文章重點了解一下golang的rpc包。

介紹

golang的rpc支持三個級別的RPC:TCP、HTTP、JSONRPC。但Go的RPC包是獨一無二的RPC,它和傳統(tǒng)的RPC系統(tǒng)不同,它只支持Go開發(fā)的服務器與客戶端之間的交互,因為在內部,它們采用了Gob來編碼。

Go RPC的函數只有符合下面的條件才能被遠程訪問,不然會被忽略,詳細的要求如下:

  • 函數必須是導出的(首字母大寫)

  • 必須有兩個導出類型的參數,

  • 第一個參數是接收的參數,第二個參數是返回給客- 戶端的參數,第二個參數必須是指針類型的

  • 函數還要有一個返回值error

舉個例子,正確的RPC函數格式如下:

        		

延伸閱讀

學習是年輕人改變自己的最好方式-Java培訓,做最負責任的教育,學習改變命運,軟件學習,再就業(yè),大學生如何就業(yè),幫大學生找到好工作,lphotoshop培訓,電腦培訓,電腦維修培訓,移動軟件開發(fā)培訓,網站設計培訓,網站建設培訓學習是年輕人改變自己的最好方式