Netty-ChannelHandler 的热插拔机制

public class UseOnceHandel extends ChannelInboundHandlerAdapter {
    public static final AttributeKey USED = AttributeKey.newInstance("Used");

    @Override
    public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
        System.out.println("此处理器只会运行一次,第二次会移除此处理器,可以用来作登录验证之类的功能");
        Attribute attr = ctx.channel().attr(USED);
        if(attr==null || attr.get()==null) {
            ctx.channel().attr(USED).set(true);
        }else {
            if(attr.get()){
                //移除此处理器
                ctx.pipeline().remove(this);
            }
        }
        super.channelRead(ctx, msg);
    }

    @Override
    public void handlerRemoved(ChannelHandlerContext ctx) throws Exception {
        System.out.println("UseOnceHandel处理器已移除");
    }
}
  1. 如果有很多业务逻辑的 handler 都要进行某些相同的操作,我们完全可以抽取出一个 handler 来单独处理
  2. 如果某一个独立的逻辑在执行几次之后(这里是一次)不需要再执行了,那么我们可以通过 ChannelHandler 的热插拔机制来实现动态删除逻辑,应用程序性能处理更为高效

你可能感兴趣的:(Netty,NIO)