2019-05-14 13:57:02 +08:00
|
|
|
### kratos tool protoc
|
|
|
|
|
2019-08-16 11:15:38 +08:00
|
|
|
```shell
|
|
|
|
# generate all
|
2019-05-14 13:57:02 +08:00
|
|
|
kratos tool protoc api.proto
|
2019-08-16 11:15:38 +08:00
|
|
|
# generate gRPC
|
2019-05-14 13:57:02 +08:00
|
|
|
kratos tool protoc --grpc api.proto
|
2019-08-16 11:15:38 +08:00
|
|
|
# generate BM HTTP
|
2019-05-14 13:57:02 +08:00
|
|
|
kratos tool protoc --bm api.proto
|
2019-08-16 11:15:38 +08:00
|
|
|
# generate ecode
|
|
|
|
kratos tool protoc --ecode api.proto
|
|
|
|
# generate swagger
|
2019-05-14 13:57:02 +08:00
|
|
|
kratos tool protoc --swagger api.proto
|
|
|
|
```
|
|
|
|
|
2020-03-28 18:02:25 +08:00
|
|
|
执行生成如 `api.pb.go/api.bm.go/api.swagger.json/api.ecode.go` 的对应文件,需要注意的是:`ecode`生成有固定规则,需要首先是`enum`类型,且`enum`名字要以`ErrCode`结尾,如`enum UserErrCode`。详情可见:[example](https://github.com/go-kratos/kratos/tree/master/example/protobuf)
|
2019-05-14 13:57:02 +08:00
|
|
|
|
2019-08-16 11:15:38 +08:00
|
|
|
> 该工具在Windows/Linux下运行,需提前安装好 [protobuf](https://github.com/google/protobuf) 工具
|
2019-05-14 13:57:02 +08:00
|
|
|
|
2019-08-16 11:15:38 +08:00
|
|
|
`kratos tool protoc`本质上是拼接好了`protoc`命令然后进行执行,在执行时会打印出对应执行的`protoc`命令,如下可见:
|
2019-05-14 13:57:02 +08:00
|
|
|
|
2019-08-16 11:15:38 +08:00
|
|
|
```shell
|
2020-03-28 18:02:25 +08:00
|
|
|
protoc --proto_path=$GOPATH --proto_path=$GOPATH/github.com/go-kratos/kratos/third_party --proto_path=. --bm_out=:. api.proto
|
|
|
|
protoc --proto_path=$GOPATH --proto_path=$GOPATH/github.com/go-kratos/kratos/third_party --proto_path=. --gofast_out=plugins=grpc:. api.proto
|
|
|
|
protoc --proto_path=$GOPATH --proto_path=$GOPATH/github.com/go-kratos/kratos/third_party --proto_path=. --bswagger_out=:. api.proto
|
|
|
|
protoc --proto_path=$GOPATH --proto_path=$GOPATH/github.com/go-kratos/kratos/third_party --proto_path=. --ecode_out=:. api.proto
|
2019-05-14 13:57:02 +08:00
|
|
|
```
|
|
|
|
|