登录
首页 >  Golang >  Go问答

两种不同语言之间的 Protocol Buffer

来源:stackoverflow

时间:2024-04-18 18:27:34 148浏览 收藏

大家好,今天本人给大家带来文章《两种不同语言之间的 Protocol Buffer》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

我们使用 golang 和 .net core 作为我们的内部通信微服务基础设施。 服务中的所有数据都基于我们创建的 protobuffs 协议。 以下是我们的 protobuff 之一的示例:

syntax = "proto3";
package protos;
option csharp_namespace = "protos";
option go_package="protos";
message eventmessage {
    string actiontype = 1;
    string payload = 2;
    bool auditisactive = 3;
}

golang 运行良好,该服务正在根据需要生成内容并将其发送到 sqs 队列,一旦发生这种情况,.net 核心服务就会获取数据并尝试对其进行序列化。

以下是 sqs 消息示例的内容:

{"@type":"type.googleapis.com/protos.eventmessage","actiontype":"pushpayload","payload":"<>"}

但是我们收到一个异常,表明线路类型未定义,如下所述:

Google.Protobuf.InvalidProtocolBufferException: Protocol message contained a tag with an invalid wire type.
   at Google.Protobuf.UnknownFieldSet.MergeFieldFrom(CodedInputStream input)
   at Google.Protobuf.UnknownFieldSet.MergeFieldFrom(CodedInputStream input)
   at Google.Protobuf.UnknownFieldSet.MergeFieldFrom(UnknownFieldSet unknownFields, CodedInputStream input)
   at Protos.EventMessage.MergeFrom(CodedInputStream input) in /Users/maordavidzon/projects/github_connector/GithubConnector/GithubConnector/obj/Debug/netcoreapp3.0/EventMessage.cs:line 232
   at Google.Protobuf.MessageExtensions.MergeFrom(IMessage message, Byte[] data, Boolean discardUnknownFields, ExtensionRegistry registry)
   at Google.Protobuf.MessageParser`1.ParseFrom(Byte[] data)

这两个服务中的 proto 文件完全相同。

是否有任何我们需要添加的潜在缺失选项或属性?


解决方案


您似乎使用的是 JSON 格式而不是二进制格式。在这种情况下,为 you want ParseJson(string json), not ParseFrom(byte[] data)

注意:如果您很重要的话,二进制格式会更有效。它还对 protobuf 库/工具有更好的支持。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《两种不同语言之间的 Protocol Buffer》文章吧,也可关注golang学习网公众号了解相关技术文章。

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