Netty 的 Handler 链调用机制

本文介绍了Netty中的Handler及其组织方式。Handler是处理事件的核心组件,分为入站和出站两种,通过ChannelHandlerContext组织成双向链表。Netty的Pipeline通过这个链表来调度事件,入站事件从头向后遍历,出站事件从尾向前遍历,每个Handler调用next()方法将事件传递给下一个处理器。若不调用next(),事件将停止传递。
摘要由CSDN通过智能技术生成

什么是 Handler

  • Netty是一款基于NIO的异步事件驱动网络应用框架,其核心概念之一就是Handler。而Handler是Netty中处理事件的核心组件,用于处理入站和出站的数据流,实现业务逻辑和网络协议的处理。

  • 在Netty中,Handler是一个接口,主要分为两种:ChannelInboundHandler(入站Handler)和ChannelOutBoundHandler(出站Handler),如下图所示。

    • ChannelInboundHandler :处理从网络通道中读取到的数据,包括解码、反序列化、消息分发等操作;
    • ChannelOutboundHandler:可以负责将处理结果编码、加密并通过网络通道发送出去等

Handler 是怎么被组织起来的

  • 为了方便事件在各个Handler中处理与传递,在Netty中,每一个ChannelHandler被封装为一个ChannelHandlerContext

    • ChannelHandlerContext提供了对ChannelHandler的访问,以及它前后相邻的ChannelHandler的访问。在ChannelHandlerContext的抽象实现类
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值