在 Docker 中生成 ProtoBuffer、gRPC 文件

时间:2022-07-22
本文章向大家介绍在 Docker 中生成 ProtoBuffer、gRPC 文件,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

使用 znly/protoc 这个镜像来在docker中生成 protobuffer 和 grpc 文件。

Python 语言版

基本用法:

docker run --rm  --user `id -u ${USER}` -v `pwd`:`pwd` -w `pwd` znly/protoc 
  	--plugin=protoc-gen-grpc=/usr/bin/grpc_python_plugin 
  	--python_out=生成的pb文件路径 --grpc_out=生成的grpc的pb文件路径 
  	-I路径 pb文件名

假设我们的项目结构长这样:

api/v1/my_server.proto 放置.pb文件
client/ 放置生成的pb文件,如 xx_pb2.py, xx_pb2_grpc.py
Makefile

首先编辑 Makefile:

client/my_server_pb2.py client/my_server_pb2_grpc.py: api/v1/my_server.proto
	@docker run --rm  --user `id -u ${USER}` -v `pwd`:`pwd` -w `pwd` znly/protoc 
  	--plugin=protoc-gen-grpc=/usr/bin/grpc_python_plugin 
  	--python_out=client --grpc_out=client 
  	-Iapi/v1 my_server.pb

compile-proto: client/my_server_pb2.py client/my_server_pb2_grpc.py

注意 @ 是在调用 make 命令时不输出当前指令。

接下来,我们在命令行执行 make compile-proto 就可以了。


Go 语言版

.pb.go 文件

如果说我们想直接生成 .pb.go 文件到proto文件同一个目录下,可以这样写:

api/v1/my_server.pb.go: api/v1/my_server.proto
	@docker run --rm --user `id -u ${USER}` -v `pwd`:`pwd` -w `pwd` znly/protoc -I. 
        --go_out=plugins=grpc:. api/v1/my_server.proto

pb 文件

如果说我们要生成一个 .pb 文件到 client 目录下:

client/my_server.pb: api/v1/my_server.proto
	@docker run --rm --user `id -u ${USER}` -v `pwd`:`pwd` -w `pwd` znly/protoc -I. 
	--include_imports --include_source_info 
	--descriptor_set_out=client/my_server.pb 
	--go_out=plugins=grpc:. api/v1/my_server.proto