Netty笔记(六)

本文介绍了Netty中Channel的生命周期变化过程,包括从注册到激活再到非激活和注销的不同阶段,并探讨了如何通过ChannelPromise处理异步操作,强调了在读写数据时避免资源泄露的重要性,以及如何利用Netty提供的工具进行资源泄露检测。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、Channel的生命周期

ChannelRegistered(注册状态,注册到EvenLoop) --> ChannelActive(活动状态,已经连接到远程节点,可以接受和发送数据) --> ChannelInactive(没有连接到远程节点) --> ChannelUnregistered(未注册到EvenLoop)

2、ChannelPromise是ChannelFuture的子类,ChannelPromise可以通过setSuccess()使ChannelFuture不可变

3、调用ChannelInboundHandler.chanelRead()和ChannelOutboundHandler.write()处理数据的时候,需要保证没有任何资源的泄露。

4、在完全使用完某个ByteBuf后,需要调整其引用计数

5、Netty提供ResourceLeakDetector检查潜在的资源泄露问题

6、每一个新创建的Channel都会被分配一个新的ChannelPipeline,这项是永久关联的。

7、ChannelHandlerContext使得ChannelHandler能够和他的ChannelPipeline以及其他的ChannelHandler交互

8、ChannelHandlerContext和ChannelHandler之间的关联(绑定)是永远不会改变的,所以缓存对他的引用是安全的

9、ChannelHandlerContext的方法将产生更短的事件流,应该用这一特性获得最大性能

10、ChannelHandler可以枞树多个ChannelPipeline,所以他也可以绑定到多个ChannelHandlerContext实例(多个ChannelPipeline共享一个ChannelHandler,需要在对应的ChannelHandler上加上注解@Sharable),而这样的ChannelHandler必须是线程安全的。

11、必须确认是线程安全的状态,才能使用@Sharable注解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值