Netty笔记(六)

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注解

猜你喜欢

转载自blog.csdn.net/u012817635/article/details/80389970