Redis 04 Reactor

Reactor 设计模式是事件驱动的并发处理模式,高效处理多个输入源的请求。多路分解事件,同步分发到处理器。

单线程 reactor 模型

redis6.0 之前采用单线程 reactor 模型。即业务线程完成网络IO及命令处理。

reactor 模型处理三类事件:

  1. 连接事件。客户端请求连接。
  2. 读事情。实例读取客户端的命令。
  3. 写事件。实例查询得到的键值对返回给客户端。

针对三类事件,Reactor 模型提出三个处理器:

acceptor:负责处理连接。建立连接后,创建 handler。

handler: 处理读写事件。

reactor:专门监听和分配事件给 acceptor 或者 handler。

redis 实例启动时,向 reactor 注册连接事件,reactor 监听客户端发起的连接事件。

客户端发起连接请求,reactor将连接事件分发给 acceptor 处理器。处理器将连接所关系的读事件注册到 reactor 。

客户端发送命令,reactor 监听到读事件,将读事件分发给读处理器。

多线程 reactor 模型

redis 的性能瓶颈在网络IO。因此 redis6.0 之后采用多线程 reactor 模型。

即业务线程将 IO 事件交给IO线程处理。业务线程只处理事件分发和读取数据。

相关推荐
Leo.yuan几秒前
不同数据仓库模型有什么不同?企业如何选择适合的数据仓库模型?
大数据·数据库·数据仓库·信息可视化·spark
麦兜*17 分钟前
MongoDB 6.0 新特性解读:时间序列集合与加密查询
数据库·spring boot·mongodb·spring·spring cloud·系统架构
chat2tomorrow20 分钟前
数据采集平台的起源与演进:从ETL到数据复制
大数据·数据库·数据仓库·mysql·低代码·postgresql·etl
稻草人想看远方23 分钟前
关系型数据库和非关系型数据库
数据库
考虑考虑24 分钟前
Postgerssql格式化时间
数据库·后端·postgresql
千里码aicood32 分钟前
【springboot+vue】党员党建活动管理平台(源码+文档+调试+基础修改+答疑)
java·数据库·spring boot
TDengine (老段)1 小时前
TDengine 选择函数 Max() 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
驾驭人生1 小时前
Asp .Net Core 系列:Asp .Net Core 集成 Hangfire+MySQL
数据库·mysql·.netcore
xhbh6661 小时前
不止是DELETE:MySQL多表关联删除的JOIN语法实战详解
数据库·mysql·程序员·mysql删除语句