当前位置:网站首页>Protocol Buffer usage
Protocol Buffer usage
2022-08-01 20:34:00 【Cloud full of notes】
1. Protocol Buffer 使用
1.1. Prerequisites
- Go, any one of the three latest major releases of Go.
For installation instructions, see Go’s Getting Started guide.
- Protocol buffer compiler,
protoc, version 3.
For installation instructions, see Protocol Buffer Compiler Installation.
- Go plugins for the protocol compiler:
Install the protocol compiler plugins for Go using the following commands:
$ go install google.golang.org/protobuf/cmd/[email protected]
$ go install google.golang.org/grpc/cmd/[email protected]
Update your PATH so that the protoc compiler can find the plugins:
$ export PATH="$PATH:$(go env GOPATH)/bin"
1.2. protoc 工具使用
前面我们用 protoc 来编译 .proto 文件为 go 语言, 为了支持编译为 go, 需要安装 protoc-gen-go 插件, C# 可以安装 protoc-gen-zsharp 插件.
需要注意的是, 转换 .proto 为编程语言, 不一定要安装 protoc.
例如 C# 只需要把 .proto 文件放到项目中, 通过包管理器安装一个库, 就会自动转换为相应的代码.
回归正题, 聊一下 protoc 编译 .proto 文件的命令.
protoc 常用的参数如下:
--proto_path=. #指定proto文件的路径, 填写 . 表示就在当前目录下
--go_out=. #表示编译后的文件存放路径; 如果编译的是 csharp, 则 --csharp_out
--go_opt={
xxx.proto}={
xxx.proto的路径} # 示例: --go_opt=Mprotos/bar.proto=example.com/project/protos/foo
最简单的编译命令:
protoc --go_out=. *.proto
--{xxx}_out 指令是必须的, 因为要输出具体的编程语言代码.
这个输出文件的路径是执行命令的路径, 如果我们不在 .proto 文件目录下执行命令, 则输出的代码便不是相同位置了.为了解决这个问题, 我们可以使用:
--go_opt=paths=source_relative
这样在别的地方执行命令, 生成的代码会跟 .proto 文件放在相同的位置.
1.3. protoc-gen-go
protoc-gen-go is a plugin for the Google protocol buffer compiler to generate Go code. Install it by building this program and making it accessible within your PATH with the name:
protoc-gen-go
The ‘go’ suffix becomes part of the argument for the protocol compiler, such that it can be invoked as:
protoc --go_out=paths=source_relative:. path/to/file.proto
This generates Go bindings for the protocol buffer defined by file.proto. With that input, the output will be written to:
path/to/file.pb.go
See the README and documentation for protocol buffers to learn more:
https://developers.google.com/protocol-buffers/
1.4. 参考
边栏推荐
- 基于FPGA的任意字节数(单字节、多字节)的串口(UART)发送(含源码工程)
- latex paper artifact -- server deployment overleaf
- 【kali-信息收集】(1.6)服务的指纹识别:Nmap、Amap
- 面试突击70:什么是粘包和半包?怎么解决?
- Does LabVIEW really close the COM port using VISA Close?
- AQS原理和介绍
- Godaddy domain name resolution is slow and how to use DNSPod resolution to solve it
- Use WeChat official account to send information to designated WeChat users
- 油猴hook小脚本
- 外骨骼机器人(七):标准步态数据库
猜你喜欢
随机推荐
通俗解释:什么是临床预测模型
WhatsApp群发实战分享——WhatsApp Business API账号
系统收集集
Fork/Join线程池
Use WeChat official account to send information to designated WeChat users
Redis 做签到统计
乐观锁批量跟新 纯SQL
使用Huggingface在矩池云快速加载预训练模型和数据集
第57章 业务逻辑之业务实体与数据库表的映射规则定义
密码学的基础:X.690和对应的BER CER DER编码
面试突击70:什么是粘包和半包?怎么解决?
LTE time domain and frequency domain resources
漏刻有时文档系统之XE培训系统二次开发配置手册
给定中序遍历和另外一种遍历方法确定一棵二叉树
Interview assault 70: what is the glue bag and a bag?How to solve?
"No title"
KDD2022 | Self-Supervised Hypergraph Transformer Recommendation System
密码学的基础:X.690和对应的BER CER DER编码
【Dart】dart构造函数学习记录(含dart单例模式写法)
Debug一个ECC的ODP数据源








