总结一下用grpc
协议写服务的若干心得,并记录一些有用链接。
-
下载grpc依赖及安装grpc代码生成工具, 也可参见该链接创建简单可行的
helloworld
服务。 -
golang
开发grpc
服务用"google.golang.org/grpc"
, 参考此例子, 及阅读官方的tutorial可以应付大部分开发情况。 -
grpc
服务端及客户端均需要保留protoc
生成的.pb.go
文件作为交互依据。 -
.
proto
文件指定了grpc
服务端和客户端交互的序列化规定,即指定了客户端如何将请求内容序列化成字节, 服务端收到请求字节后也根据.proto
文件的内容反序列化成对象。 理解上跟在go
结构体属性的json:"user_name"
类似,只是proto的序列化和反序列化效率更高。 -
使用
protoc
生成的.pb.go
文件也会生成json",,,"
和db:",,,"
等tag, 方便开发者在restful
服务和grpc
服务自由转换和选择, protoc本身不支持指定json:...
tag的命名, 只能通过辅助插件在生成.pb.go
时或事后修改.pb.go
的tag属性。 -
若在原
restful web
服务中开发grpc
服务, 可将原指定数据交互的数据结构文件如model.go/types.go
与.pb.go
合为一份。但这也会引起一系列问题。如生产的pb.go
中的结构体不支持embedded, 以及不能指定生成的pb.go
中的结构体去使用本身以经用golang
定义好的结构体。 -
Restful web
服务开发和grpc
服务交互也会引起很多序列化麻烦,尽量在开发前设计好序列化流程, 可将json,protobuf, db
等三者的序列化由同一个model定义, 省去互相转换的麻烦。