背景
protobuf是一种用于序列化结构数据的工具,实现数据的存储与交换,与编程语言和开发平台无关。
序列化:将结构数据或者对象转换成能够用于存储和传输的格式。
反序列化:在其他的计算环境中,将序列化后的数据还原为结构数据和对象。
定义数据的结构,然后使用protoc编译器生成源代码,在各种数据流中使用各种语言进行编写和读取结构数据。甚至可以更新数据结构,而不破坏由旧数据结构编译的已部署程序。
为什么用protobuf
socket通信在数据传输方面,大部分是采用json格式传输,但IM这里使用二进制传输。而使用了protobuf,它数据是二进制形式,也就是0/1,这样在实时聊天的时候,数据体积小、传输快、占用带宽小,、解析快,效能更高。
Protocol Buffers
Protocol Buffers是为了把服务端提供的proto后缀文件转换成js文件,通过调用生成后的文件的js方法对数据进行序列化和反序列化。
https://github.com/protocolbuffers/protobuf/releases
https://repo1.maven.org/maven2/com/google/protobuf/protoc/
protobuf与JSON和XML对比
- XML、JSON、protobuf都具有数据结构化和数据序列化的能力。
- XML、JSON更注重数据结构化,关注可读性和语义表达能力;protobuf 更注重数据序列化,关注效率、空间、速度,可读性较差,语义表达能力不足。
- protobuf的应用场景更为明确,XML、JSON的应用场景更为丰富。
将.proto
生成.js
文件
protoc --js_out=import_style=commonjs,binary:. ./test.proto
如果不配置环境变量,解压protoc-3.20.1-win64,进入bin目录下,把test.proto
拷贝到当前目录下,运行cmd,执行protoc --js_out=import_style=commonjs,binary:. ./test.proto
命令,便可生成test_pb.js
文件