关于golang写grpc 服务记录

总结一下用grpc协议写服务的若干心得,并记录一些有用链接。

  1. 下载grpc依赖及安装grpc代码生成工具, 也可参见该链接创建简单可行的helloworld服务。

  2. golang 开发grpc服务用"google.golang.org/grpc", 参考此例子, 及阅读官方的tutorial可以应付大部分开发情况。

  3. grpc服务端及客户端均需要保留protoc生成的.pb.go文件作为交互依据。

  4. .proto文件指定了grpc服务端和客户端交互的序列化规定,即指定了客户端如何将请求内容序列化成字节, 服务端收到请求字节后也根据.proto文件的内容反序列化成对象。 理解上跟在go结构体属性的json:"user_name"类似,只是proto的序列化和反序列化效率更高

  5. 使用protoc生成的.pb.go文件也会生成json",,,"db:",,,"等tag, 方便开发者在restful服务和grpc服务自由转换和选择, protoc本身不支持指定json:... tag的命名, 只能通过辅助插件在生成.pb.go时或事后修改.pb.go的tag属性。

  6. 若在原restful web服务中开发grpc服务, 可将原指定数据交互的数据结构文件如model.go/types.go.pb.go合为一份。但这也会引起一系列问题。如生产的pb.go中的结构体不支持embedded, 以及不能指定生成的pb.go中的结构体去使用本身以经用golang定义好的结构体。

  7. Restful web服务开发和grpc服务交互也会引起很多序列化麻烦,尽量在开发前设计好序列化流程, 可将json,protobuf, db等三者的序列化由同一个model定义, 省去互相转换的麻烦。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值