目录
高性能web服务器Nginx,Redis,Netty都是基于Reactor模式的。
Reactor模式由Reactor线程、Handler处理器组成。类似于事件驱动模式。
- Reactor线程:负责相应IO事件,并且分发到Handlers处理器。
- Handles处理器:非阻塞的执行业务处理逻辑。
单线程Reactor
Reactor和Handlers处于一个线程中执行。
多线程Reactor
- 升级Handler。既要使用多线程,又要尽可能高效率,则可以使用线程池。
- 升级Reactor。可以考虑引入多个Selector(选择器),提升选择大量通道的能力。
总体来说,多线程Reactor模式大致如下:
- 将负责数据传输的IOHandler处理器的执行放入独立的线程池中,这样,业务处理线程和负责新连接监听的反应器线程就能相互隔离,避免服务器的连接监听收到受阻。
- 如果服务器为多核CPU,可以将反应器线程拆分成多个子反应器(SubReactor)线程;同时引入多个选择器,并且为每个SubReactor引入一个线程,一个线程负责一个选择器的事件轮询。这样充分利用了系统资源,大大提升了反应器管理大量连接或者监听大量传输通道的能力 。