ChannelHandler

arcstack约 577 字大约 2 分钟

ChannelHandler

Channel 的生命周期

状态描述
ChannelUnregisteredChannel 已创建,但还未注册到 EventLoop
ChannelRegisteredChannel 已注册到了 EventLoop
ChannelActiveChannel 已经连接到它的远程节点,可以接受和发送数据
ChannelInactiveChannel 没有连接到远程节点

正常的生命周期:

ChannelRegistered -> ChannelActive -> ChannelInactive -> ChannelUnregistered

ChannelHandler 的生命周期

方法描述
handlerAdded把ChanneHandler添加到ChannelPipeline时被调用
handlerRemoved从ChannelPipeline中移除ChannelHandler时被调用
exceptionCaught处理过程中在ChannelPipeline中有错误产生时被调用

ChannelInboundHandler 接口

处理入站数据以及各种状态变化。

方法描述
channelRead从Channel读取数据时被调用
channelReadComplete从Channel上一个读操作完成时被调用
channelWritablityChangedChannel 的可写状态发生改变时被调用
userEventTriggered当ChannelnboundHandler.fireUserEventTriggered()方法被调用时被调用,因为一个POJO 被传经了ChannelPipeline

ReferenceCountUtil 释放消息资源:

@Sharable
public class DiscardHandler extends ChannelInboundHandlerAdapter {
    @Override
    public void channelRead(ChannelHandlerContext ctx, Object msg) {
        ReferenceCountUtil.release(msg);
    }
}

SimpleChannelInboundHandler 会自动释放资源,所以不应该存储指向任何消息的引用供将来使用,因为这些引用都将会失效。

public class SimpleDiscardHandler
        extends SimpleChannelInboundHandler<Object> {
    @Override
    public void channelRead0(ChannelHandlerContext ctx,
                             Object msg) {
        // No need to do anything special
    }
}

ChannelOutboundHandler 接口

ChannelOutboundHandler 一个强大的功能是可以按需推迟操作或者事件。

方法描述
bind(ChannelHandlerContext, SocketAddress, ChannelPromise)当请求将Channel绑定到本地地址时被调用
connect(ChannelHandlerContext, SocketAddress, ChannelPromise)当请求连接到远程节点时被调用
close(ChannelHandlerContext, ChannelPromise)当请求关闭Channel时被调用
deregister(ChannelHandlerContext, ChannelPromise)当请求将Channel 从它的EventLoop 注销时被调用
read(ChannelHandlerContext)当请求从Channel 读取更多的数据时被调用
flush(ChannelHandlerContext)当请求通过Channel 将入队数据冲刷到远程节点时被调用
write(ChannelHandlerContext, Object, ChannelPromise)当请求通过Channel 将数据写到远程节点时被调用

ChannelPromise 是 ChannelFuture 的一个子类,ChannelOutboundHandler 中的大部分方法都需要一个 ChannelPromise参数,以便在操作完成时得到通知。

ChannelHandlerAdapter

ChannelHandlerAdapter 提供了实用方法 isSharable(),如果其对应的实现被标注成 @Sharable,那么这个方法将返回true,表示它可以被添加到多个 ChannelPipeline 中。

共享 ChannelHandler 一个常见的用途是用于收集跨越多个 channel 的统计信息。

资源管理

idea 配置 edit configuration -- vm options -- -Dio.netty.leakDetectionLevel=ADVANCED

上次编辑于:
贡献者: javatodo,Dc.s