golang之Protobuf

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语言,就需要protocprotoc-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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值