Protobuf 名词解释
Protobuf:是由google公司用于数据交换的序列结构化数据格式,具有跨平台、跨语言、可扩展特性,类型于常用的XML及JSON,但具有更小的传输体积、更高的编码、解码能力,特别适合于数据存储、网络数据传输等对存储体积、实时性要求高的领域。以 .proto为后缀,有自己的编译器 protoc, protoc2 和 protoc3 版本,protobuf文档,简称pb。
前情提要
下面的流程建立在安装好go环境以及设置好对应的环境变量,设置如下
export GOROOT=/usr/local/go
export GOPATH=/usr/local/gocode
export GOBIN=$GOPATH/bin
export PATH=$PATH:$GOROOT:$GOPATH:$GOBIN
引出
如果你想把数据从Protobuf 格式编译成go语言,就需要protoc和protoc-gen-go2个工具。
protoc解释:是Protobuf编译器,可以借助这个工具把 .proto 文件转译成各种编程语言对应的源码,包含数据类型定义、调用接口等。我们可以从github上直接下载源码或者是编译好的包https://github.com/protocolbuffers/protobuf/releases/
安装步骤
1:选择一个版本:protoc-3.11.4-linux-x86_64.zip
2:解压:unzip protoc-3.11.4-linux-x86_64.zip -d /usr/local/
3:确认/usr/local/bin 目录下是否有proto 如果有则说明成功
protoc-gen-go解释:是go版本的 Protobuf 编译器插件,也可以从github下载https://github.com/golang/protobuf
安装步骤
1:下载下来
2:扔到src下面
3:进入到 protoc-gen-go目录 然后go build、go install即可在$GOPATH/bin目录下发现这个工具
测试
1:建立一个test.proto文件 把下面的代码放进去
//这里的语法必须使用proto2,在proto3的版本中和optional参数冲突了
syntax = "proto2";
//显式生命报名,在其他消息格式定义中可以使用package.message的方式来使用类型
//比如main.HelloWorld
package main;
message HelloWorld {
required int32 id = 1;
required string name = 2;
optional int32 opt = 3;
}
2:执行 protoc --go_out=./ test.proto 如果正常则在同级目录下会看见生成一个test.pb.go,否则结合报错查看下面的解决方案
可能会出现的问题
出现 protoc-gen-go: program not found or is not executable 报错 要么是没装好,要么是环境变量设置的不对,解决方案参考:https://github.com/golang/protobuf/issues/795