当前位置:首页 > 科技  > 软件

为什么 Go Protobuf 不支持标签注入?

来源: 责编: 时间:2024-05-29 08:58:07 302观看
导读大家好,我是煎鱼。前几天我们交流了 gogo/protobuf 前两年开始 Deprecated,作者最终放弃更新的事情,还是挺让人深思的。其作者在最终对官方 protobuf 库最绝望的一个事情,莫过于他朝朝暮暮,但官方一直不愿支持的标签注入功

大家好,我是煎鱼。GrR28资讯网——每日最新资讯28at.com

前几天我们交流了 gogo/protobuf 前两年开始 Deprecated,作者最终放弃更新的事情,还是挺让人深思的。GrR28资讯网——每日最新资讯28at.com

其作者在最终对官方 protobuf 库最绝望的一个事情,莫过于他朝朝暮暮,但官方一直不愿支持的标签注入功能。这也是很多人使用 gogo/protobuf 的原因。GrR28资讯网——每日最新资讯28at.com

如下图所示:GrR28资讯网——每日最新资讯28at.com

图片图片GrR28资讯网——每日最新资讯28at.com

标签注入是什么功能

我们来看看 gogo/protobuf 扩展(包含自定义结构注入标签功能),这是 gogo 的王牌功能之一,这是他的介绍:GrR28资讯网——每日最新资讯28at.com

图片图片GrR28资讯网——每日最新资讯28at.com

其在 gogo.proto[1] 支持了各种各样的 EnumOptions、FileOptions、MessageOptions、FieldOptions 等。GrR28资讯网——每日最新资讯28at.com

我们最常见编码诉求是调整生成 struct 时字段的 JSON tag,对应 jsontag 的功能:GrR28资讯网——每日最新资讯28at.com

图片图片GrR28资讯网——每日最新资讯28at.com

Proto 定义示例:GrR28资讯网——每日最新资讯28at.com

message Person {  string name = 1;  int32 id = 2 [(gogoproto.jsontag) = "id"];  // Unique ID number for this person.  string email = 3;  enum PhoneType {    MOBILE = 0;    HOME = 1;    WORK = 2;  }  message PhoneNumber {    string number = 1;    PhoneType type = 2;  }  repeated PhoneNumber phones = 4;  google.protobuf.Timestamp last_updated = 5;}

通过 protoc 和 plugin 生成后的 Go 代码:GrR28资讯网——每日最新资讯28at.com

type Person struct { Name        string                 `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` Id          int32                  `protobuf:"varint,2,opt,name=id,proto3" json:"id"` Email       string                 `protobuf:"bytes,3,opt,name=email,proto3" json:"email,omitempty"` Phones      []*Person_PhoneNumber  `protobuf:"bytes,4,rep,name=phones,proto3" json:"phones,omitempty"` LastUpdated *timestamppb.Timestamp `protobuf:"bytes,5,opt,name=last_updated,jsnotallow=lastUpdated,proto3" json:"last_updated,omitempty"`}

生成后的结构体中的 Id 字段,json tag 值为 id,没有了 omitempty。可以解决很多同学在与前端对接时的一些烦恼。GrR28资讯网——每日最新资讯28at.com

图片图片GrR28资讯网——每日最新资讯28at.com

除此之外还有很多用法,有兴趣的同学可以详细查看 More Canonical Go Structures[2]。GrR28资讯网——每日最新资讯28at.com

为什么官方不支持

那为什么 golang/protobuf 一直不支持这些 protobuf 的扩展功能特性呢?GrR28资讯网——每日最新资讯28at.com

图片图片GrR28资讯网——每日最新资讯28at.com

直接明确拒绝,引来社区大范围表情反对。(并没有什么用)。GrR28资讯网——每日最新资讯28at.com

具体 golang/protobuf 不支持的原因,其项目成员在社区的多年争斗下,给出了相对明确的答复。GrR28资讯网——每日最新资讯28at.com

如下图所示:GrR28资讯网——每日最新资讯28at.com

图片图片GrR28资讯网——每日最新资讯28at.com

图片图片GrR28资讯网——每日最新资讯28at.com

  • 这个功能在 Go 语言中非常实用,官方承认且认可。
  • 如果调整或支持此功能,均超出了 golang/protobuf 包的适用范围。因为官方包的定义是不与某一门编程语言强相关。
  • 如果 golang/protobuf 实现了这个功能,会出现其他语言无法有效利用此特性的情况。

说白了,官方觉得这个特性太 Go 语言定制化了,不愿意支持。GrR28资讯网——每日最新资讯28at.com

有什么替代方案

虽然现在 gogo 这一个开源项目已经进入废弃阶段,但根据 issues 内推荐的情况。可以选择继续使用 gogo,或者使用 protoc-go-inject-tag[3] 这一个项目。GrR28资讯网——每日最新资讯28at.com

简单例子,Proto 定义:GrR28资讯网——每日最新资讯28at.com

// file: test.protosyntax = "proto3";package pb;option go_package = "/pb";message IP {  // @gotags: valid:"ip"  string Address = 1;  // Or:  string MAC = 2; // @gotags: validate:"omitempty"}

通过 protoc 和 plugin 生成后的 Go 代码:GrR28资讯网——每日最新资讯28at.com

type IP struct { // @gotags: valid:"ip" Address string `protobuf:"bytes,1,opt,name=Address,jsnotallow=address" json:"Address,omitempty" valid:"ip"`}

可以明确看懂 json tag 多了 valid:"ip",符合我们在 proto 文件中声明的注解诉求。GrR28资讯网——每日最新资讯28at.com

总结

通过两篇文章梳理下来,对于整个前因后果和功能特性,我们都有了相对全面的学习和了解了。GrR28资讯网——每日最新资讯28at.com

官方 golang/protobuf 固然有自己的原则,社区也有自己的需求。开源的项目过大了,长年累月下来会难维护。GrR28资讯网——每日最新资讯28at.com

可能像 protoc-go-inject-tag 这种较为单一职责的开源库,会活的更好,也会更好找到新的人衔接。也是一个不错的方向。GrR28资讯网——每日最新资讯28at.com

参考资料

[1]gogo.proto: https://github.com/gogo/protobuf/blob/master/gogoproto/gogo.protoGrR28资讯网——每日最新资讯28at.com

[2]More Canonical Go Structures: https://github.com/gogo/protobuf/blob/master/extensions.md#more-canonical-go-structuresGrR28资讯网——每日最新资讯28at.com

[3]protoc-go-inject-tag: https://github.com/favadi/protoc-go-inject-tagGrR28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-91372-0.html为什么 Go Protobuf 不支持标签注入?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 大型前端应用如何做系统融合?

下一篇: 2024 年面向前端开发的七个最佳图表库

标签:
  • 热门焦点
  • 官方承诺:K60至尊版将会首批升级MIUI 15

    全新的MIUI 15今天也有了消息,在官宣了K60至尊版将会搭载天玑9200+处理器和独显芯片X7的同时,Redmi给出了官方承诺,K60至尊重大更新首批升级,会首批推送MIUI 15。也就是说虽然
  • 对标苹果的灵动岛 华为带来实况窗功能

    继苹果的灵动岛之后,华为也在今天正式推出了“实况窗”功能。据今天鸿蒙OS 4.0的现场演示显示,华为的实况窗可以更高效的展现出实时通知,比如锁屏上就能看到外卖、打车、银行
  • 直屏旗舰来了 iQOO 12和K70 Pro同台竞技

    旗舰机基本上使用的都是双曲面屏幕,这就让很多喜欢直屏的爱好者在苦等一款直屏旗舰,这次,你们等到了。据博主数码闲聊站带来的最新爆料称,Redmi下代旗舰K70 Pro和iQOO 12两款手
  • K6:面向开发人员的现代负载测试工具

    K6 是一个开源负载测试工具,可以轻松编写、运行和分析性能测试。它建立在 Go 和 JavaScript 之上,它被设计为功能强大、可扩展且易于使用。k6 可用于测试各种应用程序,包括 Web
  • CSS单标签实现转转logo

    转转品牌升级后更新了全新的Logo,今天我们用纯CSS来实现转转的新Logo,为了有一定的挑战性,这里我们只使用一个标签实现,将最大化的使用CSS能力完成Logo的绘制与动画效果。新logo
  • 得物效率前端微应用推进过程与思考

    一、背景效率工程随着业务的发展,组织规模的扩大,越来越多的企业开始意识到协作效率对于企业团队的重要性,甚至是决定其在某个行业竞争中突围的关键,是企业长久生存的根本。得物
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己“当家”的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • iQOO Neo8 Pro评测:旗舰双芯加持 最强性能游戏旗舰

    【Techweb评测】去年10月,iQOO推出了一款Neo7手机,该机搭载了联发科天玑9000+,配备独显芯片Pro+,带来了同价位段最佳的游戏体验,一经上市便受到了诸多用
  • 世界人工智能大会国际日开幕式活动在世博展览馆开启

    30日上午,世界人工智能大会国际日开幕式活动在世博展览馆开启,聚集国际城市代表、重量级院士专家、国际创新企业代表,共同打造人工智能交流平台。上海市副市
Top