版本说明
windows 10
go 1.17
protoc 3.17.3
protoc-gen-go 1.5.2
github.com/golang/protobuf v1.5.2
google.golang.org/grpc v1.45.0
google.golang.org/protobuf v1.28.0
安装protoc
从https://github.com/protocolbuffers/protobuf/releases下载发布的二进制文件,
放入本地path中
安装插件protoc-gen-go
go install google.golang.org/protobuf/cmd/protoc-gen-go@v1.5.2
或者
go install google.golang.org/protobuf/cmd/protoc-gen-go@latest
定义完proto文件后(比如,test.proto,包含消息定义和服务接口定义),有两种途径生成go文件。
途径一,直接利用protoc来生成
protoc --go_out=. --go-grpc_out=. proto/*.proto
这样生成会生成两个.go文件,一个是对应消息test.pb.go,一个对应服务接口test_grpc.pb.go。
在test_grpc.pb.go中,在我们定义的服务接口中,多增加了一个私有的接口方法:
mustEmbedUnimplementedTestServiceServer()
并有生成的一个UnimplementedTestServiceServer结构体来实现了所有的服务接口。因此,在我们自己实现的服务类中,需要继承这个结构体,如:
type TestServer struct {
test.UnimplementedTestServiceServer
}
然后在TestServer上实现我们的服务接口。
途径二,利用插件protoc-gen-go来生成
protoc --go_out=plugins=grpc:. proto/*.proto
这样只会生成一个.go文件,test.pb.go,消息和服务接口都在此文件中。但是此方法不会在我们定义的服务接口中新增私有接口方法。虽然仍然还会生成UnimplementedTestServiceServer结构体来实现所有的服务接口。因此,在我们自己实现的服务类时,就有了两种选择,可以继承这个结构体,也可以不继承这个结构体。