netty channel的线程安全性与@Sharable

 

1. Bootstrap中直接添加sb.childHandler(new MySimpleChannelInboundHandler())html

这个childHandler都是同一个实例,也就说会致使不一样的channel用了同一个handler安全

 

2. netty的一大好处就是每个channel都有本身绑定的eventloop和channelHandler,这样能够保证代码串行执行,没必要考虑并发同步的问题。多线程

 

3. 只要写个类继承ChannelInitializer就好了,ChannelInitializer这个类比较特殊,你能够把它想象成是不少channelhandler的集合体,并且这个类就是@Shareable的,继承了这个类以后你能够为每个channel单首创建handler,甚至是多个handler。并发

虽然全部的channel都共享了ChannelInitializerImpl这个实例,可是这个实例却能为每个channel new出新的handler实例,这就是区别。oop

 

https://www.fanyeong.com/2016/10/24/netty-channelhandler%E4%BD%BF%E7%94%A8%E6%8A%A5%E9%94%99/spa

 

4. 也并非说ChannelInitializer就能够不用@Sharable了,要视具体状况而看,若是ChannelInitializer中仍是同一个handler实例,就不行.net

https://blog.csdn.net/supper10090/article/details/78431948线程

 

5. 为了安全地被用于多个并发的Channel(即链接),sharable注解的ChannelHandler必须是线程安全的。netty

每个新建立的Channel都将会被分配一个新的ChannelPipeline,但其中的handler未必是htm

https://www.jianshu.com/p/b241e3800fc0

 

6. 若是ChannelHandler被注解为 @Sharable,全局只有一个handler实例,它会被多个Channel的Pipeline共享,会被多线程并发调用,所以它不是线程安全的;若是存在跨ChannelHandler的实例级变量共享,须要特别注意,它可能不是线程安全的。

在整个ChannelPipeline执行过程当中,可能会发生线程切换。此时,若是同一个对象在多个ChannelHandler中被共享,可能会被多线程并发操做

https://blog.csdn.net/y_xianjun/article/details/48341749

 

7. 总之,只应该在肯定了你的 ChannelHandler 是线程安全的时才使用@Sharable 注解 

http://www.cnblogs.com/krcys/p/9297092.html

 

8. 新建一个Channel时会自动新建一个ChannelPipeline,也就是说他们之间是一对一的关系。另外须要注意的是:ChannelPipeline是线程安全的,也就是说,咱们能够动态的添加、删除其中的ChannelHandler。

个人理解:channel属于一个线程,ChannelPipeline属于一个channel,因此对ChannelPipeline的操做始终在一个线程内

Sharable注解的使用是有限制的,多个ChannelPipeline只有一个实例,因此该Handler要求 无状态。不能使用或改变自己的私有变量,由于ChannelHandler是 非线程安全的,使用私有变量会形成线程竞争而产生错误结果。


连接:https://www.jianshu.com/p/7dc5da98694c

 

9. 看书

channelpipeline 始终在一个线程操做

红色框划重点

 

概括就是:

(1)channel-1vs 1 pipeline-new handler

(2)channel-1vs 1 pipeline-common handler,须要@Sharable,且确保线程安全无成员变量

(3)channel始终在一个线程中,pipeline也是,但handler未必是

 

下面补充一个关于channel与线程的实践  9.6

https://www.cnblogs.com/silyvin/articles/9599778.html

相关文章
相关标签/搜索