ProtobufVarint32FrameDecoder和ProtobufDecoder区别
1. ProtobufVarint32FrameDecoder 的输出是 去除了 Varint32 长度头的纯 protobuf 消息体,确保:
-
消息完整性(无粘包/半包问题)。
-
直接适配
ProtobufDecoder的输入要求。
2. ProtobufDecoder 用于处理 Protocol Buffers (protobuf) 二进制数据的解码器,其 处理后的结果是将字节流(ByteBuf)转换为具体的 Java 对象(即 protobuf 生成的 Message 子类)
-
接收前驱解码器的输出:
-
前驱通常是
ProtobufVarint32FrameDecoder,负责提供完整的消息体(不含长度前缀)。
-
-
解析二进制数据:
-
根据
protoc生成的 Java 类(如MyMessage),将ByteBuf反序列化为对象。
-
-
传递对象给下一个处理器:
输出解码后的对象,供后续 ChannelHandler(如业务处理器)使用。
ProtobufDecoder 的输出是 完全解析后的 protobuf Java 对象,其核心作用包括:
-
二进制 → 对象转换:将网络字节流反序列化为内存中的结构化数据。
-
与业务逻辑衔接:直接提供可操作的对象,避免手动解析。
浙公网安备 33010602011771号