go grpc安裝使用教程
gRPC是由Google主導(dǎo)開(kāi)發(fā)的RPC框架,使用HTTP/2協(xié)議并用ProtoBuf作為序列化工具。其客戶端提供Objective-C、Java接口,服務(wù)器側(cè)則有Java、Golang、C++等接口,從而為移動(dòng)端(iOS/Androi)到服務(wù)器端通訊提供了一種解決方案。 當(dāng)然在當(dāng)下的環(huán)境下,這種解決方案更熱門(mén)的方式是RESTFull API接口。該方式需要自己去選擇編碼方式、服務(wù)器架構(gòu)、自己搭建框架(JSON-RPC)。
1. 前提
- 確保go的版本在1.6及以上
- 確保glibc版本在2.14及以上(protoc需要2.14及以上版本)
2. 下載protocol buffer v3版本編譯器
下載地址: https://github.com/google/protobuf/releases
當(dāng)前最新版本為v3.5.1
3. 下載protoc的golang插件
go get -u github.com/golang/protobuf/protoc-gen-go ## 不能直接訪問(wèn)google.golang.org網(wǎng)址時(shí), 從github下載然后放到google.golang.org目錄 mkdir -p src/google.golang.org/ cd src/google.golang.org git clone https://github.com/google/go-genproto genproto
4. 下載golang實(shí)現(xiàn)的grpc
## 可直接訪問(wèn)google.golang.org時(shí) go get -u google.golang.org/grpc ## 同樣不能訪問(wèn)google.golang.org是采用的方法 mkdir -p src/google.golang.org cd src/google.golang.org git clone https://github.com/grpc/grpc-go grpc cd - ## 另外, grpc依賴的其他包需要一并下載 mkdir -p src/golang.org/x cd src/golang.org/x git clone https://github.com/golang/net git clone https://github.com/golang/text cd -
5. 編寫(xiě)用于gRPC的pb文件
6. 編譯pb生成go代碼
7. 編寫(xiě)客戶端服務(wù)端代碼并編譯運(yùn)行
上述三步可以參考grpc-go的示例代碼
8. 補(bǔ)充glibc升級(jí)步驟
查看glibc版本號(hào)
strings /lib64/libc.so.6 | grep GLIBC_
下載并安裝glibc
tar -zxf glibc-2.14.tar.gz cd glibc-2.14 mkdir build cd build ../configure --prefix=/opt/glibc-2.14 make && make install
制作軟連接
rm -f /lib64/libc.so.6 ln -s /opt/glibc-2.14/lib/libc-2.14.so /lib64/libc.so.6
注意問(wèn)題
刪除libc.so.6之后會(huì)導(dǎo)致系統(tǒng)命令不可用的情況
例如提示:
rm: error while loading shared libraries: libc.so.6: cannot open shared object file: No such file or directory
解決辦法:
LD_PRELOAD=/opt/glibc-2.14/lib/libc-2.14.so ln -s /opt/glibc-2.14/lib/libc-2.14.so /lib64/libc.so.6
如果升級(jí)失敗,回滾方法:
LD_PRELOAD=/lib64/libc-2.12.so ln -s /lib64/libc-2.12.so /lib64/libc.so.6
總結(jié)
以上所述是小編給大家介紹的go grpc安裝使用教程,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
詳解golang中?work與?module?的區(qū)別與聯(lián)系
Go?模塊通常由一個(gè)項(xiàng)目或庫(kù)組成,并包含一組隨后一起發(fā)布的?Go?包,Go?模塊通過(guò)允許用戶將項(xiàng)目代碼放在他們選擇的目錄中并為每個(gè)模塊指定依賴項(xiàng)的版本,解決了原始系統(tǒng)的許多問(wèn)題,本文將給大家介紹一下golang中?work與?module?的區(qū)別與聯(lián)系,需要的朋友可以參考下2023-09-09Golang中Delve版本太低無(wú)法Debug的問(wèn)題
這篇文章主要介紹了Golang中Delve版本太低無(wú)法Debug的問(wèn)題,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11使用Golang實(shí)現(xiàn)AES加解密的代碼示例
在現(xiàn)代的數(shù)據(jù)安全中,加密和解密是極其重要的一環(huán),其中,高級(jí)加密標(biāo)準(zhǔn)(AES)是最廣泛使用的加密算法之一,本文將介紹如何使用Golang來(lái)實(shí)現(xiàn)AES加密和解密,需要的朋友可以參考下2024-04-04Go 簡(jiǎn)單實(shí)現(xiàn)多租戶數(shù)據(jù)庫(kù)隔離
本文主要介紹了Go 簡(jiǎn)單實(shí)現(xiàn)多租戶數(shù)據(jù)庫(kù)隔離,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05Go標(biāo)準(zhǔn)庫(kù)日志打印及同時(shí)輸出到控制臺(tái)與文件
Go語(yǔ)言內(nèi)置的log包實(shí)現(xiàn)了簡(jiǎn)單的日志服務(wù),下面這篇文章主要給大家介紹了關(guān)于Go標(biāo)準(zhǔn)庫(kù)日志打印及同時(shí)輸出到控制臺(tái)與文件的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11Golang 操作 Kafka 如何設(shè)置消息的失效時(shí)間
在使用 Golang 操作 Kafka 時(shí),你可以使用 Sarama 庫(kù)來(lái)設(shè)置消息的失效時(shí)間,這篇文章主要介紹了Golang操作Kafka設(shè)置消息的失效時(shí)間,需要的朋友可以參考下2023-06-06多階段構(gòu)建優(yōu)化Go?程序Docker鏡像
這篇文章主要為大家介紹了多階段構(gòu)建優(yōu)化Go?程序Docker鏡像,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08