# 网络模型优化历程简介

<div drawio-diagram="132"><img src="http://wiki.shopqorg.com/uploads/images/drawio/2024-04/drawing-1-1714291369.png" alt=""/></div>

<div drawio-diagram="143"><img src="http://wiki.shopqorg.com/uploads/images/drawio/2024-04/drawing-1-1714293610.png" alt=""/></div>

<div drawio-diagram="144"><img src="http://wiki.shopqorg.com/uploads/images/drawio/2024-04/drawing-1-1714296852.png" alt=""/></div>

##### **Netty模型介绍：**

1. **Netty网络模型包含两组线程池，分别是BossGroup 和 workGroup**
2. bossGroup负责客户端连接，WorkGroup 负责网络读写
3. BossGroup和WorkGroup的类型都是NIOEventLoopGroup
4. NIOEventLoopGroup 相当于一个事件循环组，这个组中含有多个事件循环，每一个事件循环都是NioEventLoop
5. NioEventLoop表示一个不断执行处理任务的线程，每个NioEventLoop都有一个Selector,用于监听绑定在其上的socket网络通讯
6. NIOEventLoopGroup可以有多个线程，即可以包含多个NioEventLoop
7. 每个Boss NioEventLoop 循环执行的步骤如下 
    1. 轮询accept事件
    2. 处理accept事件，与client建立连接，生成NioServerSocketChannel,将其注册到work NIOEventLoop上的selector
    3. 处理任务队列的任务，即runAllTask
8. 每个Work NioEventLoop 循环执行的步骤如下 
    1. 轮询read、write事件
    2. 处理I/O事件，在对应的NioSocketChannel中处理
    3. 处理任务队列的任务，即runAllTask
9. 每个worker NioEventLoop处理业务时，会使用pipeline（管道），pipeline中包含channel

<div drawio-diagram="149"><img src="http://wiki.shopqorg.com/uploads/images/drawio/2024-04/drawing-1-1714299318.png" alt=""/></div>