Netty回调与Channel执行流程分析

 Chanel的生命周期:

状态描述
ChannelUnregisteredChannel已被创建,但未注册到EventLoop
ChannelRegisterd

Channel注册到EventLoop

ChannelActiveChannel处于活动状态
ChannelInactiveChannel没有连接到远程节点

Channel的状态发生改变是,会生成相应的事件,这些事件将会转发给ChannelPipline中的ChannelHandler.

 

ChannelHandler的生命周期:

在ChannelHandler被添加到ChannelPipline中或被从ChannelPipline中移除时回调用这些操作。

ChannelHandler中重要的子接口:

使用了适配器模式--对核心的ChannelHandler及其子类进行包装以向外提供接口。当你想在自己的ChannelHandler中使用这些适配器类,只需要简单的扩展它们,并且重写你想自定义的方法例如channelRead0();

  • ChannelInBoundHandler---处理入站数据以及各种状态变化
  • ChannelOutBoundHandler---处理出站数据并且允许拦截所有的操作

ChannelInBoundHandler接口:

我们常用的是SimpleChannelInboundHandler它继承自ChannelInboundHandlerAdapter, ChannelInboundHandlerAdapter的执行流程[我们在使用一个体系的时候,要参阅顶层,使用底层对象]:

如果在项目中直接使用ChannelInboundHandlerAdapter比较繁琐,需要自己来释放资源,而SimpleChannelInboundHandler会自动释放资源。

   // 实现了上层的接口channelRead--所以不需要我们自己释放资源
    public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
        boolean release = true;
        try {
            if (this.acceptInboundMessage(msg)) {
                this.channelRead0(ctx, msg); // 调用我们自定义的方法
            } else {
                release = false;
                ctx.fireChannelRead(msg);
            }
        } finally {
            if (this.autoRelease && release) {
                ReferenceCountUtil.release(msg); // 此处释放了资源
            }
        }
    }
    // 我们只需要继承SimpleChannelInboundHandler,然后实现channelRead0这个方法即可
    protected abstract void channelRead0(ChannelHandlerContext var1, I var2) throws Exception;

调用的顺序:

 ChannelInBoundHandler接口:

出站操作和数据将由ChannelOutboundHandler处理。它的方法将被Channel、ChannelPipLine以及ChannelHandlerContext调用。其强大功能就是可以按需推迟操作或者事件,使得可以通过复杂的方法处理请求。

ChannelOutboundHandler中的大部分方法都需要一个ChannelPromise参数以便在操作完成时得到通知。ChannelPromise是ChannelFuture的一个子类,定义了一些可写的方法,如setSuccess()和setFailure(),从而使ChannelFuture不可变。

Netty是一个基于Java的网络应用框架,它提供了一种高效、可扩展的方式来开发网络应用程序。在Netty中,回调函数是一种常见的处理方式,用于处理异步操作的结果。 在高并发场景下,合理的回调函数设计可以提高系统的性能和可伸缩性。以下是一些关于Netty高并发合理的回调函数的介绍: 1. ChannelFutureListener:ChannelFutureListener是一个回调接口,用于监听I/O操作的结果。通过添加ChannelFutureListener,可以在I/O操作完成后执行相应的逻辑。在高并发场景下,可以使用ChannelFutureListener来处理大量的并发请求,例如在写入操作完成后释放资源或发送响应。 2. Promise和Future:Promise和Future是Netty中用于处理异步操作的接口。Promise表示一个异步操作的结果,而Future表示一个异步操作的凭证。通过Promise和Future,可以实现更加灵活的回调函数设计,例如在多个异步操作完成后执行某个逻辑。 3. ChannelHandler:ChannelHandler是Netty中用于处理I/O事件的组件。通过实现自定义的ChannelHandler,可以在不同的事件发生时执行相应的回调函数。在高并发场景下,可以根据具体需求实现自定义的ChannelHandler来处理并发请求,例如进行请求分发、连接管理等。 4. EventLoop:EventLoop是Netty中用于处理事件的线程。每个Channel都会绑定一个EventLoop,用于处理该Channel上的事件。通过合理地使用EventLoop,可以实现高效的事件处理和回调函数执行。 总结起来,Netty提供了多种处理异步操作的回调函数机制,可以根据具体需求选择合适的方式来设计高并发的回调函数。合理的回调函数设计可以提高系统的性能和可伸缩性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值