grpc之Protobuf编译器

参考:
https://zhuanlan.zhihu.com/p/103489208
protobuf的介绍、安装与使用

protobuf是google旗下的一款平台无关,语言无关,可扩展的序列化结构数据格式。
所以很适合用做数据存储和作为不同应用,不同语言之间相互通信的数据交换格式,只要实现相同的协议格式即同一 proto文件被编译成不同的语言版本,加入到各自的工程中去。
这样不同语言就可以解析其他语言通过 protobuf序列化的数据。

1 数据交互格式比较
json
一般的web项目中,最流行的主要还是json。
因为浏览器对于json数据支持非常好,有很多内建的函数支持。
json使用了键值对的方式,不仅压缩了一定的数据空间,同时也具有可读性。

xml
webservice中应用最为广泛,
但是相比于json,它的数据更加冗余,因为需要成对的闭合标签

protobuf
谷歌开源的一种数据格式,
适合高性能,对响应速度有要求的数据传输场景。
因为profobuf是二进制数据格式,需要编码和解码。
数据本身不具有可读性。
因此只能反序列化之后得到真正可读的数据。

2 protobuf优势

(1) 序列化后体积相比Json和XML很小,适合网络传输
(2) 支持跨平台多语言
(3) 消息格式升级和兼容性还不错
(4) 序列化、反序列化速度很快,快于Json的处理速速

3 protobuf安装生成protoc工具
(1)下载 protobuf安装包

  $ git clone https://github.com/protocolbuffers/protobuf.git

(2)安装依赖库

  $ sudo apt-get install autoconf automake libtool curl make g++ unzip libffi-dev -y

(3)安装

  $ cd protobuf/
  $ ./autogen.sh
  $ ./configure
  $ make
  $ sudo make install
  $ sudo ldconfig                  // 刷新共享库,很重要的一步

(4)测试一下是否安装成功

 $ protoc –h

(5)获取 proto包(Go语言的proto API接口)

 $ go get -v -u github.com/golang/protobuf/proto

(6)进入GOPATH/src/github.com/golang/protobuf/protoc-gen-go目录下,打开终端,输入:

 $ go build

(7)将build生成的protoc-gen-go可执行文件复制到/bin目录下

 $ sudo cp protoc-gen-go /bin/

4 语法
参考proto.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值