登录
首页 >  Golang >  Go问答

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

来源:stackoverflow

时间:2024-05-01 22:00:41 203浏览 收藏

Golang不知道大家是否熟悉?今天我将给大家介绍《Go protobuf 中单独消息和服务定义的最佳实践?》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

问题内容

在(go 特定的)protocol buffers 中分离服务中使用的消息声明的最佳实践是什么?上下文是一个具有多个 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

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


解决方案


不确定它是否有帮助,或者您是否使用的是不同版本的 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

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Go protobuf 中单独消息和服务定义的最佳实践?》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>