gRPC是由Google主導開發的RPC框架,使用HTTP/2協議并用ProtoBuf作為序列化工具。其客戶端提供Objective-C、Java接口,服務器側則有Java、Golang、C++等接口,從而為移動端(iOS/Androi)到服務器端通訊提供了一種解決方案。 當然在當下的環境下,這種解決方案更熱門的方式是RESTFull API接口。該方式需要自己去選擇編碼方式、服務器架構、自己搭建框架(JSON-RPC)。
1. 前提
- 確保go的版本在1.6及以上
- 確保glibc版本在2.14及以上(protoc需要2.14及以上版本)
2. 下載protocol buffer v3版本編譯器
下載地址: https://github.com/google/protobuf/releases
當前最新版本為v3.5.1
3. 下載protoc的golang插件
1
2
3
4
5
|
go get -u github.com /golang/protobuf/protoc-gen-go ## 不能直接訪問google.golang.org網址時, 從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實現的grpc
1
2
3
4
5
6
7
8
9
10
11
12
13
|
## 可直接訪問google.golang.org時 go get -u google.golang.org /grpc ## 同樣不能訪問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. 編寫用于gRPC的pb文件
6. 編譯pb生成go代碼
7. 編寫客戶端服務端代碼并編譯運行
上述三步可以參考grpc-go的示例代碼
8. 補充glibc升級步驟
查看glibc版本號
1
|
strings /lib64/libc .so.6 | grep GLIBC_ |
下載并安裝glibc
1
2
3
4
5
6
|
tar -zxf glibc-2.14. tar .gz cd glibc-2.14 mkdir build cd build .. /configure --prefix= /opt/glibc-2 .14 make && make install |
制作軟連接
1
2
|
rm -f /lib64/libc .so.6 ln -s /opt/glibc-2 .14 /lib/libc-2 .14.so /lib64/libc .so.6 |
注意問題
刪除libc.so.6之后會導致系統命令不可用的情況
例如提示:
1
|
rm : error while loading shared libraries: libc.so.6: cannot open shared object file : No such file or directory |
解決辦法:
1
|
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 |
如果升級失敗,回滾方法:
1
|
LD_PRELOAD= /lib64/libc-2 .12.so ln -s /lib64/libc-2 .12.so /lib64/libc .so.6 |
總結
以上所述是小編給大家介紹的go grpc安裝使用教程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
原文鏈接:https://my.oschina.net/hncscwc/blog/1620386