网络通信消息序列化protobuf
概述
网络通信数据传输常见的序列化方式:
-
- 互联网的http/https的api的打包采用json格式
-
- 更早的网络通信也有采用xml封装的数据
-
- 通信领域用到的asn.1数据编码
-
- 更常见的消息格式:标签/长度/value的TLV方式
对于互联网盛行的时代,json格式和xml数据封装格式此处不做详解,主要介绍TLV与protbuf两种模式。
- 更常见的消息格式:标签/长度/value的TLV方式
常见的消息格式TLV
TLV 结构由三个基本部分组成:
- Tag(标签)
标识字段的类型,给数据字段打“标签”。可以是数值、字符或者其他预定义的标识符,用于指示后面的数据的意义。Tag 可以是单个字节,也可以是多个字节,根据标识的数量和范围而定。 - Length(长度)
Length 字段用来表示 Value 字段的长度,可以是一个字节、两个字节或更多,根据 数据Value 的最大可能长度确定。Length 字段通常采用变长编码,较短的 Value,使用较少的比特位就能表示其长度,节省空间。 - Value(值)
Value 是数据内容,可以是整数、字符串、二进制数据块等。由于TLV 格式 Value 长度不定,可以传输不同类型和长度的数据。 - TLV 序列化的优势
扩展性:方便添加新的类型,对现有的数据解析不影响。
灵活性:数据长度根据需要而定,节省网络带宽。
健壮性:软件版本不同,不识别的消息无法解析,可以跳过处理后续的 TLV 单元。 - 举例
开灯命令数据内容value的内容举例:
+0 4 bytes light_id —灯的唯一id
+4 2 bytes building_id —楼栋号
+6 2