不用了解Protobuf语法也能轻松使用golang开发GRPC服务
go2proto 可以很轻松的根据Golang定义的接口生成proto文件,很大程度简化GRPC服务的开发工作。当公司要使用GRPC开发项目的时候就不用再感叹学不动了
- 创建一个user.go, 写入如下内容
package server
type User interface {
Createuser(request Request) Response
}
type Request struct {
Name string
}
type Response struct {
Result string
}
- 生成proto文件
在user.go 同目录下执行 go2proto -f user.go
就会自动在当前目录的proto文件夹生成user.proto 文件
// Code generated by go2proto. DO NOT EDIT.
syntax = "proto3";
package proto;
service User {
rpc Createuser (Request) returns (Response) {}
}
message Request {
string Name = 1;
}
message Response {
string Result = 1;
}
是不是很简单呢,可以完全不用了解Protobuf语法,只要用Go定义接口就可以
go get -u github.com/akkagao/go2proto
安装完执行 go2proto 如果能输出一下内容则说明安装成功
➜ go2proto git:(master) ✗ go2proto
go2proto version: go2proto/1.0.0
Usage: go2proto [-f] [-t]
Options:
-f string
source file path
-t string
proto file target path (default "proto")
-f 参数用于指定 go接口文件
-t 参数用于指定生成的proto文件存储的目录
由于这里定义服务的go文件只是用于生成proto文件,建议不要在代码中引用这里定义的struct。
切记由于proto中的字段顺序都是有编号的,所以不要轻易删除字段或修改字段顺序。尤其是项目发布后。
重要的事情说三遍:
不要删除字段,不要修改顺序
不要删除字段,不要修改顺序
不要删除字段,不要修改顺序
使用Go提供的源码解析工具把go文件解析成ast语法树,然后分析ast语法树内容。通过模板生成proto文件。
代码很简单关键代码不到300行,有兴趣可以花几分钟时间看一下。
https://www.jianshu.com/p/937d649039ec
https://segmentfault.com/a/1190000020386857
感谢以上两篇博客的作者