关于 2.线程模型概述 有人问能回答上来就可以了.
但是对于 Netty 模型来说, 一定要了解透彻后才继续学习.
下面的图是我自己根据网上疯传的一种一张 Netty 模型图改的, 看着是不是有点像 主从 Reactor 多线程.
Netty 抽象出了两组线程池, BossGroup 专门用来处理客户端连接, WorkerGroup 专门负责网络读写. 这两组线程池的类型为 NioEventLoopGroup
.
每一个 NioEventLoopGroup
都包含一个或多个 NioEventLoop
, NioEventLoop
就是一个不断执行任务的线程, 而且每个 NioEventLoop
都包含一个 Selector
, 用于监听绑定在其上的 socket 事件.
下面的蓝色圆圈就是 NioEventLoop
的执行步骤, 当客户端进行连接 BossGroup 就会轮询到 accept 事件, 然后封装成 NioSocketChannel
并注册到 WorkerGroup 的某个线程中的 Selector
中, 至于具体注册到哪个线程会根据算法获取, 最后执行任务队列中的任务.
这流程就是大体说了一下, 后面文章会详细说.