Redis是事件驱动的程序,并基于Reactor模式开发了自己的网络事件处理器,被称之为文件处理器(File Event Handler)。
文件处理器通过I/O多路复用程序来同时监听多个Socket,并根据Socket目前执行的任务来关联不同的事件处理器。当被监听的Socket准好执行应答(accept)、读取(read)、写入(write)和关闭(close)操作时,与操作相对应的文件事件就会产生,这时文件事件处理器就会调用Socket关联的事件处理器进行事件处理。
文件处理器构成
文件处理器主要包括Socket、I/O多路复用程序、文件派发器和事件处理器。
因为I/O多路复用同时监听多个Socket,那么一定存在多个事件并发的情况。Redis通过消息队列来解决并发的问题。通过消息队列可以有序、同步的将每个socket事件分配给文件事件派发器。
文件处理器主要包括命令应答处理器、命令请求应答器和命令回复应答器
- 命令应答处理器:为了对连接服务器的各个客户端进行应答, 服务器要为监听套接字关联连接应答处理器
- 命令请求处理器:为了接收客户端传来的命令请求,服务器要为客户端套接字关联命令请求处理器
- 命令回复处理器:为了向客户端返回命令的执行结果,服务器要为客户端套接字关联命令回复处理器
C/S交互过程
以一个完整的C/S通讯示例进行分析
- Redis服务器启动,在main函数中,通过aeMain创建文件处理器
- 服务器的监听Socket的AE_READABLE事件处于监听状态下,而该事件所对应的处理器为连接应答处理器
- 客户端发起连接请求,监听Socket产生AE_READABLE事件,触发连接应答处理器执行;
- 连接应答处理器对客户端连接进行应答,创建客户端Socket,将客户端Socket的AE_READABLE事件与命令请求处理器关联
- 客服端向服务端发送一个命令请求,客户端产生AE_READABLE事件,触发命令请求处理器执行
- 执行命令将产生相应命令回复,服务器将客户端Socket的 AE_WRITABLE 事件与命令回复处理器进行关联
- 客户端尝试读取命令回复时,客户端Socket将产生 AE_WRITABLE 事件,触发命令回复处理器
- 命令回复处理器命令回复全部写入到Socket后,服务器就会解除客户端Socket套接字的 AE_WRITABLE 事件与命令回复处理器之间的关联