protobuf3基础语法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了protobuf3基础语法相关的知识,希望对你有一定的参考价值。

参考技术A

ProtoBuf (Google Protocol Buffer)是由google公司用于数据交换的序列结构化数据格式,具有跨平台、跨语言、可扩展特性,同类型有常用的XML及JSON,但具有更小的传输体积、更高的编码、解码能力,特别适合于数据存储、网络数据传输等对存储体积、实时性要求高的领域,目前已经发展到protoc3 版本。

优点:空间效率高,时间效率要高,对于数据大小敏感,传输效率高的

缺点:消息结构可读性不高,序列化后的字节序列为二进制序列不能简单的分析有效性

备注:最后的时间类型golang需要引入包 github.com/golang/protobuf/ptypes/timestamp ,定义如下

然后 .protp 文件需要导入 google/protobuf/timestamp.proto

如果一个字段被 repeated 修饰,则表示它是一个列表类型的字段,相当于 golang 里的切片

如果你希望可以预留一些数字标签或者字段可以使用reserved修饰符

第一个枚举值的数值必须是0且至少有一个枚举值,一个数值可以对应多个枚举值,必须标明 option allow_alias = true; 不推荐使用负数值

在你的 .proto 文件中指定 service ,然后在 service 里定义 rpc方法 即可,要注意指定参数和返回值

gRPC 允许你定义4种类型的 service 方法

客户端使用存根发送请求到服务器并等待响应返回,就像平常的函数调用一样

通过在 响应返回参数 类型前插入 stream 关键字,可以指定一个服务器端的流方法。客户端发送请求到服务器,拿到一个流去读取返回的消息序列。 客户端读取返回的流,直到里面没有任何消息。

通过在 请求参数 类型前指定 stream 关键字来指定一个客户端的流方法。客户端写入一个消息序列并将其发送到服务器,同样也是使用流。一旦客户端完成写入消息,它等待服务器完成读取返回它的响应。

通过在请求和响应前加 stream 关键字去制定方法的类型。两个流独立操作,因此客户端和服务器可以以任意喜欢的顺序读写:比如, 服务器可以在写入响应前等待接收所有的客户端消息,或者可以交替的读取和写入消息,或者其他读写的组合。

protobuf语法指南

遇到proto编译问问,看看proto语法,记录一下

以上是关于protobuf3基础语法的主要内容,如果未能解决你的问题,请参考以下文章

十五.ProtoBuf3的基础总结

hbase基础语法

tcl 语法基础

BAT脚本基础语法

TS基础语法

Groovy基础语法详解