分离(特定于特定)协议缓冲区中的服务中使用的消息声明的最佳实践是什么?上下文是一个具有多个gRPC服务的大型应用程序。在多个服务中使用一些消息。其思想是将消息和服务的定义划分为如下(简化一点):
airline/pb/airline_messages.proto
syntax = "proto3";
option go_package = "github.com/example.com/example-repo/airline/pb";
message Airline {
string code = 1;
string name = 2;
string country = 3;
}airline/pb/airline_services.proto
syntax = "proto3";
option go_package = "github.com/example.com/example-repo/airline/pb";
import "airline/pb/airline_messages.proto"
service AirlineService {
rpc GetAirline(string) returns (Airline) {}
rpc GetAirlines(GetAirlinesRequest) returns (repeated Airline) {}
}
message GetAirlinesRequest {
int max = 1;
string country = 2;
string pattern = 3;
string sortby = 4;
}我这样打电话给protoc:
protoc --go_out=. \
--go_opt=paths=source_relative \
--go-grpc_out=. \
--go-grpc_opt=paths=source_relative \
--proto_path=. \
--proto_path=../../ airline_services.proto这不起作用,因为没有定义Airline。这样引用它:
protoc ... airline_services.proto airline_messages.proto生成一条错误消息,该航空公司是乘数定义的。这样做:
protoc ... airline_messages.proto
protoc ... airline_services.proto只需覆盖Go文件,就相当于编译airline_services.proto。
在多个服务中重用消息定义的最佳实践是什么?
发布于 2021-01-20 14:53:06
不确定它是否有用,或者您是否正在使用不同版本的Go生成器。
我在一个目录中有多个*.proto文件。其中一些进口:
device.proto导入status.proto的一部分
syntax = "proto3";
package somePackage;
import "status.proto";
option go_package = "goPackageName";
service Device {
rpc GetStatus (GetStatusRequest) returns (Status) {}
}
message GetStatusRequest {
// ...
}使用包含status.proto消息的Status:
syntax = "proto3";
package somePackage;
option go_package = "goPackageName";
message Status {
int32 customer = 1;
string device_id = 2;
// ...
}我用以下方式生成Go代码:
protoc --go_out=plugins=grpc:. --go_opt=paths=source_relative *.proto注意:我仍然在使用旧的Go protobuf github.com/golang/protobuf。
https://stackoverflow.com/questions/65811631
复制相似问题