前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >go 安装protobuf

go 安装protobuf

作者头像
仙士可
发布2022-01-18 13:56:42
2K0
发布2022-01-18 13:56:42
举报
文章被收录于专栏:仙士可博客仙士可博客

什么是protobuf?

protocol buffers 是一种语言无关、平台无关、可扩展的序列化结构数据的方法,它可用于(数据)通信协议、数据存储等。

Protocol Buffers 是一种灵活,高效,自动化机制的结构数据序列化方法-可类比 XML,但是比 XML 更小(3 ~ 10倍)、更快(20 ~ 100倍)、更为简单。

你可以定义数据的结构,然后使用特殊生成的源代码轻松的在各种数据流中使用各种语言进行编写和读取结构数据。你甚至可以更新数据结构,而不破坏由旧数据结构编译的已部署程序。

简单来说就是:你可以通过protobuf,将不同语言的数据结构进行直接序列化传输,由其他语言接收

安装protobuf

下载地址:https://github.com/protocolbuffers/protobuf/releases

编译安装时需要c,c++编译器

代码语言:javascript
复制
yum install gcc -y
yum install gcc-c++ -y
yum install make -y
代码语言:javascript
复制
wget 
tar -zvxf protobuf-all-3.19.3.tar.gz
cd protobuf-3.19.3
./configure
make
make install
protoc --version

即可看到安装完成

安装 go-protobuf

安装插件 protoc-gen-go,它是一个go程序,编译它之后将可执行文件执行路径写入环境变量

代码语言:javascript
复制
go get github.com/golang/protobuf/protoc-gen-go

获取go的protobuf包

代码语言:javascript
复制
go get github.com/golang/protobuf/proto

输入命令 protoc-gen-go,如果没报错表示安装成功

使用

编写一个proto文件./test/user.proto:

代码语言:javascript
复制
syntax = "proto3";
package test;
option go_package ="./test";
message User{
   string userName = 1;
   int64  userId = 2 ;
   string address = 3;
   string password = 4;
}

在根目录执行命令:

代码语言:javascript
复制
protoc --go_out=. ./test/*.proto

将生成文件:

仙士可博客
仙士可博客

main引用并使用:

代码语言:javascript
复制
package main

import (
   "encoding/json"
   "fmt"
   "google.golang.org/protobuf/proto"
   "log"
   "testProject/test"
)

func main() {
   user := test.User{}
   user.Address = "sadsda"
   user.Password = "123456"
   user.UserName = "仙士可"
   bytes, _ := json.Marshal(user)
   fmt.Println(string(bytes))
   //序列化user结构体数据
   out, err := proto.Marshal(&user)
   if err != nil {
      log.Fatalln("Failed to encode address book:", err)
   }

   //反序列化user结构体
   user2:=test.User{}
   err = proto.Unmarshal(out, &user2)
   if err!=nil {
      log.Fatalln("Failed to parse address User:", err)
   }
   bytes, _ = json.Marshal(user2)
   fmt.Println(string(bytes))
}

本文为仙士可原创文章,转载无需和我联系,但请注明来自仙士可博客www.php20.cn

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-01-17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是protobuf?
  • 安装protobuf
  • 安装 go-protobuf
  • 使用
相关产品与服务
文件存储
文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档