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线程处理。业务线程只处理事件分发和读取数据。

相关推荐
豆芽脚脚3 小时前
MongoDB 导出和导入完整指南
数据库·mongodb
烧饼Fighting3 小时前
Mysql替换为瀚高数据库部分函数转换V4.5版本
数据库·mysql
上善若水_厚德载物4 小时前
Centos7 Mysql 5.7 读写分离
数据库·mysql
Mr__Miss4 小时前
Redis的持久化
数据库·redis·缓存
CCPC不拿奖不改名5 小时前
SQL基础(SQL小白教程):MySQL语句+环境一键搭建+面试习题
数据库·sql·计算机网络·mysql·oracle·面试·职场和发展
陈文锦丫5 小时前
JAVA面试
数据库·mysql
sunfove5 小时前
将 Python 仿真工具部署并嵌入个人博客
开发语言·数据库·python
Codeking__5 小时前
Redis——基本通用命令
redis·git·github
冰清-小魔鱼6 小时前
各类数据存储结构总结
开发语言·数据结构·数据库
深藏bIue7 小时前
MongoDB 4.4.30安装、数据迁移
数据库·mongodb