go grpc安装使用教程
时间:2019-04-13
本文章向大家介绍go grpc安装使用教程,主要包括go grpc安装使用教程使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
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插件
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
## 可直接访问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版本号
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
注意问题
删除libc.so.6之后会导致系统命令不可用的情况
例如提示:
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
如果升级失败,回滚方法:
LD_PRELOAD=/lib64/libc-2.12.so ln -s /lib64/libc-2.12.so /lib64/libc.so.6
总结
以上所述是小编给大家介绍的go grpc安装使用教程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法