Netty模型-工作原理详细版

1)Netty抽象出两组线程池BossGroup 专门负责客户端的链接,WorkGroup 负责网络的读写。

2)BossGroup和WorkGroup类型都是NioEventLoopGroup

3)NioEventLoopGroup相当于一个事件循环组,这个组中包含有多个事件循环,每一个事件循环是NioEventLoop

4)NioEventLoop表示一个不断循环的执行处理任务的线程,每个NioEventLoop都有一个selector,用于监听绑定在其上的socket的网络通讯

5)NioEventLoopGroup可以有多个线程,既可以含有多个NioEventLoop

6)每个Boss NioEventLoop执行的步骤有3步

 1.轮询accept事件

    2.处理accept事件,与client建立连接,生成NioSocketChannel,并将其注册到某个work NioEventLoop上的selector

   3.处理任务队列的任务,即runAllTasks

7)每个Work NioEventLoop 循环执行的步骤

    1.轮询read,write事件

    2.处理io事件,即read,write 事件,在对应的NioSocketChannel处理

   3.处理任务队列的任务,即runAllTasks

8)每个Work NioEventLoop处理业务的时候,会使用pipeline(管道),pipeline中包含了channel,即通过pipeline可以获取对应的通道,管道中维护了很多处理器。

posted @   Alan668  阅读(112)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
点击右上角即可分享
微信分享提示