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

相关推荐
陌上丨9 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
AI_56789 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw10 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH307310 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道10 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据11 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务11 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
时艰.12 小时前
Java 并发编程 — 并发容器 + CPU 缓存 + Disruptor
java·开发语言·缓存
Goat恶霸詹姆斯12 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七13 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习