Netty之Protobuf使用与实战

本文介绍了如何在Netty中使用Protobuf进行数据编码解码,对比了Java序列化的缺点,阐述了Protobuf作为高效跨语言的序列化工具的优势,并详细展示了创建.proto文件、生成Java代码以及配置客户端和服务器端Handler的实战步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Protobuf

netty自带的编码/解码器

数据再网络中传输都是二进制字节码数据、发送数据需要编码、接收数据需要解码

codec的组成部分由两个:decoderencoder

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tcohfNaR-1606206184921)(C:\Users\acer\AppData\Roaming\Typora\typora-user-images\image-20201124105601898.png)]

缺点:

1、无法跨语言

2、底层采用java序列化技术、序列化后体积大(二进制编码的五倍多)、性能低

Protobuf介绍

1、高效的结构化数据存储格式,可用于结构化数据串行化(序列化)、适合做数据存储或者==RPC【远程过程调用 remote procedure call】数据交换格式==

2、支持跨平台、跨语言

3、高性能、高可靠性

4、将类的定义使用.proto文件进行描述

5、通过protoc.exe.proto进行编译城java文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rCxueH5X-1606206184928)(C:\Users\acer\AppData\Roaming\Typora\typora-user-images\image-20201124110829915.png)]

使用案例

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BVVkWQGS-1606206184931)(C:\Users\acer\AppData\Roaming\Typora\typora-user-images\image-20201124132106222.png)]

创建一个 .proto 文件

syntax="proto3";
option optimize_for=SPEED;//加快解析
option java_package="com.cyurs.netty.codec2"; //指定生成到那个包下
option java_outer_classname="MyDataInfo"; //指定外部类名称
//protobuf 可以使用message 管理其他message
message MyMessage{
   
   
  //定义一个枚举
  enum DataType{
   
   
    StudentType=0; //在proto3 要求enum编号从0开始
    WorkerType=1;
  }
  DataType data_type=1;  //用data_type标识传的是哪一个枚举类型
  //oneof表示每次枚举类型最多只能出现定义的message(Student、Worker)的其中一个
  oneof dataBody{
   
   
    Student student =2;
    Worker worker =3;
  }

}
message Student{
   
   
  int32 id=1; //Student类的属性
  string name =2;
}
message Worker{
   
   
  string name=1; //Student类的属性
  int32 age =2;
}

使用protoc.exe生成.java文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qvlVa23f-1606206184935)(C:\Users\acer\AppData\Roaming\Typora\typora-user-images\image-20201124161813336.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pFfwmCOG-1606206184938)(C:\Users\acer\AppData\Roaming\Typora\typora-user-images\image-20201124161820635.png)]

配置客户端Handler

public class NettyClientHandler extends ChannelInboundHandlerAdapter {
   
   
    /**
     * 当通道就绪就会触发
     * @param ctx
     * @throws Exception
     */
    @Override
    public void channelActive(ChannelHandlerContext ctx) throws Exception {
   
   

        //随机发送student或者worker对象
        int random = new Random().nextInt(2);
        MyDataInfo.MyMessage myMessage = null;
        if (random == 0) {
   
   
            myMessage = MyDataInfo.MyMessage.newBuilder().setDataType(MyDataInfo.MyMessage.DataType.StudentType)
                    .setStudent(MyDataInfo.Student.newBuilder(
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值