热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

grpc和protobuf当另一方未同步发布时如何处理新字段

我遇到的情况是grpc通信的另一端与其发布的版本不同步。我的上司,因此希望我添加一个字段,如果对方填写或不填写,该字段将在短时间内(如两周)有效我相信我可以通过将它添加到

我遇到的情况是 grpc 通信的另一端与其发布的版本不同步。我的上司,因此希望我添加一个字段,如果对方填写或不填写,该字段将在短时间内(如两周)有效

我相信我可以通过将它添加到 proto 消息的末尾来做到这一点,这样其他字段的索引就不会改变。根据我在 Google 上搜索的内容,可选字段在 3.15 版之前不可用,因此我必须使用变通方法。

向我描述的解决方法是使用oneof. 但是,我不能 100% 确定那是什么样子。所有示例都单独显示 oneof 字段。属于 oneof values 的索引是否缩进属于消息其余部分的索引?

message TestMessage {
string somefield = 1;
int someotherfield = 2;
oneof mynewoptionalfield
{
string mynewfield = ???? Does this have to be 3 or is it 1?
int ifihadanother = ???? Does this need to be 4 or 2?
}
}

问题:


  • 我在哪里使用的索引是什么???标记是

  • 当另一方不打算重新编译和部署对原型文件的更改时,这是正确的解决方法吗?

  • 然后如何检查该字段是否已填写在我的 C++ 代码中?


回答

您的用例正是 protobuf 旨在处理的。您需要做的就是:在消息中添加一个新字段。在最简单的情况下,客户端应用程序代码在服务器部署完成之前不会查看新字段,因此不会注意到它有时存在,有时不存在。

您不应该更改预先存在的字段的索引(字段 ID),这是正确的。尽管我会注意到您可以在消息中的任何位置添加新字段;字段的写入顺序对于 protobuf 无关紧要。

所以你只需添加另一个字段,如:

message TestMessage {
string somefield = 1;
int someotherfield = 2;
string mynewfield = 3;
}

你不具备使用3的ID。您可以使用 4、10 或 10000。但是对于 protobuf 来说,小数字更有效,通常只选择“下一个”ID。On-the-wire protobuf 使用 id 来标识字段,所以以后不要更改 id 很重要。

在protobuf 3中,所有字段都是protobuf 2意义上的“可选”;没有“必填”字段。但是,protobuf 2 还为所有字段提供了“现场存在”。Protobuf 3 只为 oneofs 和消息提供字段存在......直到最近重新引入“可选”关键字。

在 protobuf 3 中,如果您调用textMessage.getMynewfield()它,它将始终返回一个非空字符串。如果未发送字符串,它将使用空字符串 ( "")。对于整数0,返回消息,返回“默认消息”(所有默认值)。这对于许多用例来说已经足够了,可能对你来说已经足够了。

但是假设您需要区分""。这就是现场存在所提供的。protobuf 3 中的消息具有“has”方法,true如果存在值则返回。但是原语没有存在信息。一种选择是使用使原语成为消息的标准包装器来“装箱”原语。较新版本的 protobuf 中可用的另一个选项是optional关键字。这两个选项都将提供类似textMessage.hasMynewfield().

message TestMessage {
string somefield = 1;
int someotherfield = 2;
google.protobuf.StringValue mynewfield = 3;
// -or-
optional string mynewfield = 3;
}






推荐阅读
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
author-avatar
mobiledu2502868653
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有