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