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可以获取对应的通道,管道中维护了很多处理器。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决