当前位置: 首页 > news >正文

Netty技术全解析:MessageToMessageCodec类深度解析

❃博主首页 : 「码到三十五」 ,同名公众号 :「码到三十五」,wx号 : 「liwu0213」
☠博主专栏 : <mysql高手> <elasticsearch高手> <源码解读> <java核心> <面试攻关>
♝博主的话 : 搬的每块砖,皆为峰峦之基;公众号搜索「码到三十五」关注这个爱发技术干货的coder,一起筑基

Netty是一个高性能的网络编程框架,它提供了丰富的编解码器(Codec)来简化网络数据的处理。在Netty中,MessageToMessageCodec类是一个关键的编解码器组件,它同时实现了消息的编码和解码功能。本文将结合Netty的源码,详细分析MessageToMessageCodec类的工作原理、实现细节以及使用场景。

文章目录

      • 一、MessageToMessageCodec类概述
      • 二、源码解析
      • 三、工作原理
      • 四、使用场景
      • 五、注意事项
      • 六、结语

一、MessageToMessageCodec类概述

MessageToMessageCodec是Netty提供的一个抽象类,它同时继承了ChannelInboundHandlerAdapterChannelOutboundHandlerAdapter,因此它既可以处理入站消息(解码),也可以处理出站消息(编码)。这个类的主要作用是将业务消息对象与字节流或其他形式的消息进行相互转换,以便在网络中传输。

二、源码解析

首先,我们来看一下MessageToMessageCodec的核心源码结构。

public abstract class MessageToMessageCodec<INBOUND_IN, OUTBOUND_IN> extends ChannelDuplexHandler {// 解码方法,需要子类实现protected abstract void decode(ChannelHandlerContext ctx, INBOUND_IN msg, List<Object> out) throws Exception;// 编码方法,需要子类实现protected abstract void encode(ChannelHandlerContext ctx, OUTBOUND_IN msg, List<Object> out) throws Exception;// 处理入站消息@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {List<Object> out = decode(ctx, (INBOUND_IN) msg, null);if (out != null) {for (Object o : out) {ctx.fireChannelRead(o);}} else {// 如果没有解码出消息,则释放原始消息ReferenceCountUtil.release(msg);}}// 处理出站消息@Overridepublic void write(ChannelHandlerContext ctx, Object msg, ChannelPromise promise) throws Exception {List<Object> encoded = encode(ctx, (OUTBOUND_IN) msg, promise.task());if (encoded == null || encoded.isEmpty()) {// 如果没有编码后的消息,则释放原始消息并设置promise成功ReferenceCountUtil.release(msg);promise.setSuccess();} else {// 如果有编码后的消息,则逐个写入for (Object e : encoded) {ctx.write(e, promise);}}}// ... 其他方法和字段
}

从源码中可以看出,MessageToMessageCodec类有两个关键的抽象方法:decodeencode。子类需要实现这两个方法来完成消息的解码和编码逻辑。

  • decode方法用于将入站消息(通常是字节流)解码为业务消息对象,并将解码后的消息传递给下一个ChannelInboundHandler进行处理。
  • encode方法用于将业务消息对象编码为出站消息(通常是字节流),以便发送到网络中。

三、工作原理

  1. 解码过程

    • 当有入站消息到达时,Netty会调用MessageToMessageCodecchannelRead方法。
    • channelRead方法内部会调用子类实现的decode方法进行解码。
    • 解码过程中,decode方法会根据具体的协议逻辑将入站消息(通常是字节流)解码为业务消息对象,并将解码后的消息添加到传入的List<Object>中。
    • 解码完成后,解码后的消息会被逐个传递给下一个ChannelInboundHandler进行处理。
  2. 编码过程

    • 当有出站消息需要发送时,Netty会调用MessageToMessageCodecwrite方法。
    • write方法内部会调用子类实现的encode方法进行编码。
    • 编码过程中,encode方法会根据具体的协议逻辑将业务消息对象编码为出站消息(通常是字节流),并将编码后的消息添加到传入的List<Object>中。
    • 编码完成后,编码后的消息会被逐个写入到网络中。

四、使用场景

MessageToMessageCodec适用于需要同时处理消息的编码和解码的场景。例如,在处理自定义协议时,可以使用MessageToMessageCodec将接收到的字节流解码为业务消息对象,并将业务消息对象编码为字节流发送到网络中。

五、注意事项

  1. 线程安全MessageToMessageCodec本身不是线程安全的。如果你的编解码逻辑涉及到共享资源的访问或修改,需要确保这些操作是线程安全的。
  2. 性能考虑:在编解码过程中,MessageToMessageCodec可能会创建新的消息对象,这可能会带来一定的内存开销。因此,在使用MessageToMessageCodec时,需要权衡其带来的便利和可能的性能开销。
  3. 异常处理:在编解码过程中,如果发生异常,需要妥善处理,例如记录日志、关闭连接等。

六、结语

MessageToMessageCodec是Netty中用于处理消息编解码过程的重要工具。通过提供一个抽象的编解码框架,它使得开发者可以更容易地编写基于消息的协议编解码逻辑。希望本文能够帮助开发者更好地理解MessageToMessageCodec类的工作原理和使用方法,并在实际开发中充分利用其提供的便利。


关注公众号[码到三十五]获取更多技术干货 !

http://www.lryc.cn/news/418209.html

相关文章:

  • Three 【3D车模换肤】
  • 语言模型简介和Ngram模型(1)
  • MessageBox弹框替代系统自带的alert、confirm -- 高仿ElementUI MessageBox
  • 数据结构一排序算法
  • [Leetcode 215][Medium]-数组中的第K个最大元素-快排/小根堆/堆排序
  • 【栈和队列】常见面试题
  • 关于float浮点值二进制存储和运算精度损失的话题
  • python爬虫学习记录-请求模块urllib3
  • 谷粒商城实战笔记-133~135-城业务-商品上架-远程上架接口
  • 【React】详解 App.js 文件
  • 【ML】self-supervised Learning for speech and Image
  • 青岛实训day24(8/8)
  • *算法训练(leetcode)第四十五天 | 101. 孤岛的总面积、102. 沉没孤岛、103. 水流问题、104. 建造最大岛屿
  • 设计模式 由浅入深(待完结)
  • (第34天)645、最大二叉树
  • Python知识点:如何使用Paramiko进行SSH连接与操作
  • 代码随想录算法训练营第六天(一)|242.有效的字母异位词
  • 数据结构 | 考研代码题之顺序表 | 1 查找L中值为e的数据元素若找到则返回其下标,若找不到则返回-1
  • RLVF:避免过度泛化地从口头反馈中学习
  • 设计原则与思想-从项目实战中学习设计模式
  • python中的类属性、实例属性、类方法、实例方法和静态方法
  • A股继续底部震荡,探底是否能成功?
  • NPDP考前怎么复习?NPDP200问PDF版来啦~
  • ajax图书管理项目
  • 深入理解 Java SPI - 概念、原理、应用
  • JavaScript - 判断数组中是否包含某个的元素的几种方式
  • 如何用AI颠覆企业未来:从大企业到中小型企业的实战攻略
  • Linux磁盘管理_LVM逻辑卷_SWAP交换分区_Centos-LVM格式磁盘扩容
  • C++ 函数模板和类模板
  • 安卓Termux系统设备安装内网穿透工具实现远程使用SFTP传输文件