首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Go protobuf中单独的消息和服务定义的最佳实践?

Go protobuf中单独的消息和服务定义的最佳实践?
EN

Stack Overflow用户
提问于 2021-01-20 14:35:11
回答 1查看 2K关注 0票数 0

分离(特定于特定)协议缓冲区中的服务中使用的消息声明的最佳实践是什么?上下文是一个具有多个gRPC服务的大型应用程序。在多个服务中使用一些消息。其思想是将消息和服务的定义划分为如下(简化一点):

airline/pb/airline_messages.proto

代码语言:javascript
复制
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

代码语言:javascript
复制
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

代码语言:javascript
复制
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。这样引用它:

代码语言:javascript
复制
protoc ... airline_services.proto airline_messages.proto

生成一条错误消息,该航空公司是乘数定义的。这样做:

代码语言:javascript
复制
protoc ... airline_messages.proto
protoc ... airline_services.proto

只需覆盖Go文件,就相当于编译airline_services.proto

在多个服务中重用消息定义的最佳实践是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-20 14:53:06

不确定它是否有用,或者您是否正在使用不同版本的Go生成器。

我在一个目录中有多个*.proto文件。其中一些进口:

device.proto导入status.proto的一部分

代码语言:javascript
复制
syntax = "proto3";

package somePackage;

import "status.proto";

option go_package = "goPackageName";

service Device {
    rpc GetStatus (GetStatusRequest) returns (Status) {}
}

message GetStatusRequest {
    // ...
}

使用包含status.proto消息的Status

代码语言:javascript
复制
syntax = "proto3";

package somePackage;

option go_package = "goPackageName";

message Status {
    int32 customer = 1;
    string device_id = 2;
    // ...
}

我用以下方式生成Go代码:

代码语言:javascript
复制
protoc --go_out=plugins=grpc:. --go_opt=paths=source_relative *.proto

注意:我仍然在使用旧的Go protobuf github.com/golang/protobuf

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65811631

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档