Protobuf的使用

Protobuf使用

最近写了些pb,来代替json,pb的特点就是小,简单,序列化快一点之类的,可用于通讯协议数据存储等领域。

在做微服务的时候,先把业务拆分成独立完整的功能,从原来的模块里分离出来,然后定义pb,再通过脚本或者插件(需要protoc编译)生成java的类,pb生成的类可能就很大,不过我们不用关心,因为你不需要打开生成的java,只需要通过pb去了解它,然后通过ClassName.InnerClassName去找到你要的类。

比如: 具体参考官方文档https://developers.google.cn/protocol-buffers/docs/proto3

syntax = "proto3";

package outer.user;

import "common/errcode.proto";
import "google/protobuf/any.proto";

// true的话会分解类,false的话message、service、enum都会在一个类里
option java_multiple_files = true;
option java_package = "xx.xx.user";
option java_outer_classname = "User";

enum ErrorCode {
    // 枚举第一个要=0
    FAIL = 0;
    SUCCESS = 1;
}

message UserSearchReq {
    string user_id = 1;
}

message UserSearchResp {
    // 这里的1、2并不是值,可以理解为下标
    ErrorCode status = 1;
    string id = 2;
    string user_name = 3;
    // ....
} 

// just for example
message Example {
map<string, google.protobuf.Any> map = 1;
stirng id = 2;
int32 age = 3;
// 转成java就是List
repeated string card = 4;
// ....
} service UserXxxService {
// 查询用户,相当于接口里的方法 rpc UserSearch (UserSearchReq) returns (UserSearchResp); } // ....

推荐每个方法一个req和resp,比较清晰。

如何在代码里使用呢?

pb生成的类是通过类对应的builder去创建的,这个就是建造者模式的应用,创建的过程类似:

User.UserSearchReq.newBuilder().setUserId("1").build();

之后就是实现接口,注册服务,让别的模块去调用。

转载于:https://www.cnblogs.com/KuroNJQ/p/11432269.html

ProtobufProtocol Buffers)是一种轻量级的数据序列化格式,由Google开发。它可以用于结构化数据的序列化,用于数据通信、持久化和配置文件等场景。下面是使用protobuf的一般步骤: 1. 定义消息类型:使用protobuf语言定义文件(.proto)来描述数据结构和消息类型。你可以定义消息字段的名称、类型和规则等。 2. 编写.proto文件:在.proto文件中定义消息类型、字段和其他相关信息。例如,你可以定义消息的名称、字段的名称和类型、字段的规则(如必填、可选或重复)等。 3. 编译.proto文件:使用protobuf编译器将.proto文件编译为你所选编程语言的源代码。protobuf支持多种编程语言,如C++、Java、Python等。编译后会生成对应语言的源代码文件,其中包含与消息类型相关的类或结构体。 4. 在代码中使用protobuf:在你的代码中引入生成的源代码文件,并使用其中定义的类或结构体。你可以根据需要创建、修改和序列化protobuf消息,以及将其转换为二进制格式或其他格式。 5. 序列化和反序列化:使用protobuf库提供的方法将protobuf消息序列化为二进制格式,或者将二进制数据反序列化为protobuf消息。这样可以实现消息的传输和存储。 总结来说,使用protobuf可以实现跨语言、高效的数据序列化和反序列化,简化了数据传输和存储的过程。通过定义和编译.proto文件,并在代码中使用生成的源代码文件,你可以方便地使用protobuf进行数据处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值