如何生成protobuf文件

背景

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对比

在这里插入图片描述

  1. XML、JSON、protobuf都具有数据结构化和数据序列化的能力。
  2. XML、JSON更注重数据结构化,关注可读性和语义表达能力;protobuf 更注重数据序列化,关注效率、空间、速度,可读性较差,语义表达能力不足。
  3. 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文件

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值