![Netty权威指南](https://wfqqreader-1252317822.image.myqcloud.com/cover/711/47378711/b_47378711.jpg)
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
2.2.2 伪异步式I/O创建的TimeServer源码分析
我们对服务端代码进行一些改造,代码如下。
![](https://epubservercos.yuewen.com/1F677E/26763860101459606/epubprivate/OEBPS/Images/36_2.jpg?sign=1739253532-YTpq1wSAEYeWSfFXDYDo3UfjUgUGPYXZ-0-051c857f9fbc850e88ab28ca65e8b868)
代码清单2-4 伪异步I/O的TimeServer
![](https://epubservercos.yuewen.com/1F677E/26763860101459606/epubprivate/OEBPS/Images/37_1.jpg?sign=1739253532-EvMyjOyTMV0jGxAV8M6UOdInLbZ1nxPi-0-ba15e279723b78d839fb62da398c3d39)
伪异步I/O的主函数代码发生了变化,我们首先创建一个时间服务器处理类的线程池,当接收到新的客户端连接的时候,将请求Socket封装成一个Task,然后调用线程池的execute方法执行,从而避免了每个请求接入都创建一个新的线程。
![](https://epubservercos.yuewen.com/1F677E/26763860101459606/epubprivate/OEBPS/Images/37_2.jpg?sign=1739253532-WMoZlSuot4Ct0KXxVJT0Ra9aXsjuT4nR-0-07637b6c8e47a6060acdd4154afa5c95)
代码清单2-5 伪异步I/O的TimeServerHandlerExecutePool
![](https://epubservercos.yuewen.com/1F677E/26763860101459606/epubprivate/OEBPS/Images/38_1.jpg?sign=1739253532-PzKz561rWmWOP23h3XqttPMzfgqktNQ6-0-aaca0c085cfbf90a184894a0aa916172)
由于线程池和消息队列都是有界的,因此,无论客户端并发连接数多大,它都不会导致线程个数过于膨胀或者内存溢出,相比于传统的一连接一线程模型,是一种改良。
由于客户端代码并没有改变,因此,我们直接运行服务端和客户端,执行结果如下。服务端运行结果如图2-6所示。
![](https://epubservercos.yuewen.com/1F677E/26763860101459606/epubprivate/OEBPS/Images/38_2.jpg?sign=1739253532-15iYH16OxTafPHTWs198Qu3LXlV3O5Ab-0-091dcec34ad99850f3f21754ca1fc04e)
图2-6 伪异步I/O时间服务器服务端运行结果
客户端运行结果如图2-7所示。
![](https://epubservercos.yuewen.com/1F677E/26763860101459606/epubprivate/OEBPS/Images/38_3.jpg?sign=1739253532-ROtKHiie46fQ8nq3XD3riV9iW7cKSzGp-0-9190add4b2b8b9ed59c94586531e0806)
图2-7 伪异步I/O时间服务器客户端运行结果
伪异步I/O通信框架采用了线程池实现,因此避免了为每个请求都创建一个独立线程造成的线程资源耗尽问题。但是由于它底层的通信依然采用同步阻塞模型,因此无法从根本上解决问题。下个小节我们对伪异步I/O进行深入分析,找到它的弊端,然后看看NIO是如何从根本上解决这个问题的。