rust使用protobuf

前言

c++,java,go 等直接是用 ,具体就不说了,这章主要讲述rust 使用protobuf

这章主要讲述2种

1 > protoc + protoc-gen-rust plugin

2> protoc + prost-build

1:环境

win10

rustrover64

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

25-2 是rust 实验性的

纯粹用这个 出错了,这里先不讨论了,由解决的麻烦留个言我

3.3.0 golang编译的


2:安装 测试

1> protoc + protoc-gen-rust plugin

安装插件

cargo install protobuf-codegen 生成protoc-gen-rust

或 用源码生成

执行

protoc --rust_out=. *.proto

生成

编译测试

toml 增加

dependencies

protobuf="3.3"

2>protoc + prost-build

dependencies

prost="0.12"

prost-types = "0.12"

build-dependencies

prost-build = { version = "0.12"}#,features = ["cleanup-markdown"]

build.rs 从网上抄来的

rust 复制代码
use std::process::Command;

fn main() {
    //std::env::set_var("PROTOC", protobuf_src::protoc());
    //不增加下面一句 老是提示没权限,所以直接把环境变量写到这里
    std::env::set_var("PROTOC", "E:/work/protobuf/protobuf_proto/protoc"); //protoc_25_2 
    let mut config = prost_build::Config::new();
    config.bytes(&["."]);
    // 表示给生成的数据结构加上额外的trait,比如这里的: PartialOrd,表示对象实现排序trait
    config.type_attribute(".", "#[derive(PartialOrd)]");  //如果去掉这个比较属性,就没上面的比较重复的问题了
    config
        .out_dir("src/pb") //指定输出的目录
        .compile_protos(&["chat.proto"], &["."]) // 列举需要编译的文件
        .unwrap();

    // 下面表示调用系统cargo命令,并使用fmt进行标准代码格式化
    Command::new("cargo")
        .args(&["fmt", "--", "src/*.rs"])
        .status()
        .expect("cargo fmt failed");

    println!("proto files build finish.");
}

一个重复错误,手动修改下(因为加了 config.type_attribute(".", "#[derive(PartialOrd)]"); 这句,这个地方重复了)

编译运行

3:2种proto生成的 rs内容真不一样

4:DEMO工程 后续如有需要再上传
如果觉得有用,麻烦点个赞,加个收藏

相关推荐
星释1 小时前
Rust 练习册 :Pythagorean Triplet与数学算法
开发语言·算法·rust
星释1 小时前
Rust 练习册 :Nth Prime与素数算法
开发语言·算法·rust
码事漫谈2 小时前
智能体颠覆教育行业调研报告:英语、编程、语文、数学学科应用分析
后端
蓝-萧2 小时前
使用Docker构建Node.js应用的详细指南
java·后端
码事漫谈2 小时前
《C语言点滴》——笑着入门,扎实成长
后端
Tony Bai3 小时前
【Go模块构建与依赖管理】09 企业级实践:私有仓库与私有 Proxy
开发语言·后端·golang
咖啡教室3 小时前
每日一个计算机小知识:ICMP
后端·网络协议
间彧3 小时前
OpenStack在混合云架构中通常扮演什么角色?
后端
咖啡教室3 小时前
每日一个计算机小知识:IGMP
后端·网络协议
间彧3 小时前
云原生技术栈中的核心组件(如Kubernetes、Docker)具体是如何协同工作的?
后端