Redis文件事件模型

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通讯示例进行分析

  1. Redis服务器启动,在main函数中,通过aeMain创建文件处理器
  2. 服务器的监听Socket的AE_READABLE事件处于监听状态下,而该事件所对应的处理器为连接应答处理器
  3. 客户端发起连接请求,监听Socket产生AE_READABLE事件,触发连接应答处理器执行;
  4. 连接应答处理器对客户端连接进行应答,创建客户端Socket,将客户端Socket的AE_READABLE事件与命令请求处理器关联
  5. 客服端向服务端发送一个命令请求,客户端产生AE_READABLE事件,触发命令请求处理器执行
  6. 执行命令将产生相应命令回复,服务器将客户端Socket的 AE_WRITABLE 事件与命令回复处理器进行关联
  7. 客户端尝试读取命令回复时,客户端Socket将产生 AE_WRITABLE 事件,触发命令回复处理器
  8. 命令回复处理器命令回复全部写入到Socket后,服务器就会解除客户端Socket套接字的 AE_WRITABLE 事件与命令回复处理器之间的关联
相关推荐
杨江1 小时前
ThingsBoard安装测试
服务器·数据库
mit6.8241 小时前
[Redis#3] 通用命令 | 数据类型 | 内部编码 | 单线程 | 快的原因
linux·redis·分布式
mit6.8241 小时前
[Redis#4] string | 常用命令 | + mysql use:cache | session
数据库·redis·后端·缓存
Beekeeper&&P...2 小时前
map和redis关系
数据库·redis·缓存
一朵忽明忽暗的云2 小时前
【Redis_Day6】Hash类型
redis·hash类型
jianqimingtian2 小时前
如何使用 Matlab 制作 GrabCAD 体素打印切片
数据结构·数据库
真真假假々2 小时前
MySQL和ADSDB
数据库·mysql
秦老师Q2 小时前
MySQL第二章 sql约束与sql数据类型
数据库·sql·mysql
不是二师兄的八戒2 小时前
mysql in查询大数据量业务无法避免情境下优化
数据库·mysql
----云烟----2 小时前
Qt获取文件夹下的文件个数(过滤和不过滤的区别)
数据库·qt