• 欢迎来到本博客,希望可以y一起学习与分享

windows环境下golang使用protobuf

笔记 benz 6个月前 (03-25) 20次浏览 0个评论 扫描二维码
文章目录[隐藏]

Protobuf 介绍

序列化库在网络传输,RPC,数据库访问等环境中经常用到,它的性能的好坏直接影响着整个产品的性能, 所以我们有必要对一些优秀的序列化库进一步的学习与掌握.

protobuf是Google开发的一种数据描述语言,能够将结构化的数据序列化,可用于数据存储,通信协议等方面,官方版本支持 Go, C++, Java, Python,社区版本支持更多语言.

相对于JSON和XML具有以下优点:

  1. 简洁
  2. 体积小:是json的10分之一,xml格式的20分之一,是二进制序列化的10分之一
  3. 速度快:解析速度比XML快20 ~ 100倍
  4. 使用Protobuf的编译器,可以生成更容易在编程中使用的数据访问代码
  5. 更好的兼容性,Protobuf设计的一个原则就是要能够很好的支持向下或向上兼容
  6. protobuf将数据序列化为二进制之后,占用的空间相当小,基本仅保留了数据部分,而xml和json会附带消息结构在数据中;

IDE设置

默认情况下IDE goland 是不支持protobuf协议文件类型”.proto”的,为了更快高效的编写proto文件中的代码下面我们介绍一款插件让其支持,该插件支持关键字高亮及语法错误提示

1、File->Settings->Plugins->输入protobuf support->install,并重启IDE
注意:这里也可以安装Protocol Buffer Editor插件

2、file->Settings->Editor->File Types,找到Protobuf,注册支持*.proto

编译器配置

protobuffer属于跨平台,跨语言的协议,有自己的编译器
protoc是Protobuf编译器
下载最新的压缩包,解压后将其中的protoc.exe程序放到gopath的bin目录中,最好把gopath的bin目录添加到系统环境变量里
下载地址:https://github.com/protocolbuffers/protobuf/releases

测试

终端输入protoc --version 显示版本即代表安装成功

执行 protoc -h 正常输出 相关指令 没有报任何error,为安装成功

安装protobuf库文件

报错

解决:
参考:安装GIN框架出现依赖包GOOGLE.GOLANG.ORG/PROTOBUF无法安装的解决方法
1、将 google.golang.org/protobuf 包对应的github上的地址git或下载下来,github地址:https://github.com/protocolbuffers/protobuf-go
2、在在Go的”$GOPATH”目录的src目录下,创建“google.golang.org/protobuf” 目录;
3、将下载或git文件的protobuf-go/目录下的全部内容复制到上面创建的google.golang.org/protobuf目录下。
git clone 的protobuf-go/ 目录下的文件:

将git clone的”protobuf-go/” 目录下的全部文件复制到 “google.golang.org/protobuf “中:

最后再执行:

就不会报错了。

安装goprotobuf插件(go版本的 Protobuf 编译器插件)

注意:要先安装上面的库

没有任何信息就成功了。

示例

目录结构:

说明:
protos目录中存放我们自己要写的proto格式文件

生成.pb.go

到protos目录下执行:

pb目录下就存放生成的文件:

main函数就是主体业务逻辑,这里做序列化和反序列化演示:

参考

windows环境下golang使用protobuf
Golang Protocol Buffer教程


文章 windows环境下golang使用protobuf 转载需要注明出处
喜欢 (0)

您必须 登录 才能发表评论!