Reactor & Proactor 设计模式
平时接触的开源产品如Redis, 事件模型都使用的Reactor模式; 而同样做事件处理的Proactor, 由于操作系统的原因, 相关的开源产品较少.
1. Reactor 模式
简介
一种为处理并发服务请求, 并将请求提交到一个或者多个服务处理程序的事件设计模式.
当客户端请求抵达后, 服务处理程序使用多路分配策略, 由一个非阻塞的线程来接收所有的请求, 然后派发这些请求至相关的工作线程进行处理.
![](https://img-blog.csdnimg.cn/6c6cd60e3f0e4c5ba21aa954cd4fa8f6.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA54aK5a2p5a2Q5p2l5ZWm,size_16,color_FFFFFF,t_70,g_se,x_16)
基本组成
- 初始事件分发器(Initialization Dispatcher)
用于管理Event Handler, 定义注册, 移除EventHandler等; 还作为Reactor模式的入口调用Synchronous Event Demultiplexer的select方法以阻塞等待事件返回, 当阻塞等待返回时, 根据事件发生的Handle将其分发给对应的Event Handler处理, 即回调EventHandler中的handle_event()方法
- 多路事件分离器(Synchronous Event Demultiplexer)
无限循环等待新事件的