Redis网络模型

Redis到底是单线程还是多线程?

  • 如果仅仅聊Redis核心业务(命令处理),就是单线程
  • 如果是整个Redis就是多线程

Redis为什么选择单线程?

  • 抛开持久化不谈,Redis是纯内存操作,执行速度非常快,它的性能瓶颈是网络延迟而不是执行速度,因此多线程并不会带来巨大的性能提升
  • 多线程会导致过多上下文切换,带来不必要的开销
  • 引入多线程会面临线程安全问题,必然要引入线程锁,实现复杂性能下降

Redis 网络模型原理

一、核心架构

Redis 采用 单线程 Reactor 多路 IO 复用模型

  • 主线程:只处理网络 IO + 命令执行
  • 后台子线程:持久化、异步删除、集群同步等
二、三大核心组件
  1. IO 多路复用(epoll/kqueue/select) 同时监听海量 socket,只唤醒有事件的连接,不阻塞。
  2. 事件分离器 区分两类事件:
    • 文件事件:客户端读写、连接建立(最核心)
    • 时间事件:定时任务、过期键删除
  3. 单线程事件驱动 所有命令串行执行,无线程竞争,天生线程安全
三、完整执行流程
  1. Redis 启动创建服务端监听 socket,加入 epoll 监听
  2. 客户端发起连接 → epoll 捕获连接事件,建立客户端 socket
  3. 客户端发命令 → 触发读事件,主线程读取缓冲区命令
  4. 主线程串行执行命令(get/set/hash 等)
  5. 执行完写入响应缓冲区 → 触发写事件返回数据
  6. 全程单线程跑命令,不会并发抢资源
四、为什么单线程还快
  1. 命令执行纯内存,速度极快
  2. IO 多路复用批量处理连接,高并发扛得住
  3. 无锁竞争、无线程切换开销
  4. 耗时操作全丢后台线程(RDB/AOF、大键删除)
五、阻塞点(重点)

单线程最怕慢命令阻塞整个服务:

  • keys *、flushall、大 hash 遍历
  • 大量过期键集中删除一旦阻塞,所有客户端全部卡顿
六、6.0+ 多线程改动

IO 多线程,命令依旧单线程

  • 多线程负责:网络读写数据
  • 命令解析执行:还是主线程串行目的:提升网络 IO 吞吐,不改核心执行模型

相关推荐
J.Kuchiki6 分钟前
【PostgreSQL 内核学习:平衡 K 路归并(Balanced k-way Merge)】
数据库·学习·postgresql
徐寿春10 分钟前
什么是数据倾斜
java·guava
xieliyu.14 分钟前
MySQL 全套入门笔记:基础、库操作、数据类型
数据库·笔记·mysql
lvbinemail17 分钟前
【无标题】
数据库·postgresql·zabbix·监控
李白的天不白18 分钟前
一个服务器可以搭建多个网站
java·tomcat
●VON18 分钟前
AtomGit Flutter鸿蒙客户端:共享组件
java·flutter·华为·harmonyos·鸿蒙
程序猿乐锅19 分钟前
【JAVASE | 第十七篇】Java 网络通信
java·开发语言
执于代码20 分钟前
Java交互打印的问题
java
小小工匠22 分钟前
Redis - 缓冲区管理:避免溢出引发的“惨案“
redis·性能优化·集群·内存管理·持久化
技术小甜甜25 分钟前
[办公效率] Excel 表格越做越乱,先整理字段、格式还是公式?
数据库·excel·办公效率·数据整理