Redis真的是单线程的吗?

Redis提及它的优势点就是它的速度非常快。当我们提及Redis是否是单线程的时候我们可能会回答它的设计就是单线程访问内存存储的数据所以很快。但是你有没有考虑过为什么它的架构使用单线程?为什么隔壁的MySQL虽然访问的不是内存但是使用的还是多线程呢?以及Redis真的就是单线程的吗?

我们在说到这个问题的时候就要分清Redis6.0之前和之后的版本来讨论了。

Reids6.0之前版本:

Redis 6.0之前在I/O层面的传输采用的是Redis服务器单线程获取,业务服务器使用Socket池将业务数据并行的传输给Redis的缓冲区中,然后Redis单线程使用epll_wait()来获取数据。

"接收数据 → 解析命令 → 执行命令 → 发送响应"整个流程 全部由同一个主线程串行完成

任何一个步骤耗时过长(如 KEYS、SORT 等慢命令)都会阻塞后续所有请求

Redis6.0之后版本:

其实在Redis4.x版本已经在负责处理客户端请求的线程单线程,但是开始加了一些多线程的内容比如异步删除;在Reids6.x中全面支持了多线程。但是这个多线程也是在网络I/O中接受数据使用多线程,在命令执行中还是单线程的进行。

为什么就算是到了6.x版本仍然是单线程进行命令的处理呢?

如果想要使用多线程带来的遍历就得设计一个完美的多线程的架构方案,单线程的优势是不用考虑多线程带来的线程不安全的问题,并且redis直接操作内存已经很快了并且还有高效的数据结构,比如跳表,哈希进行查询。所以它的性能瓶颈可能只是在网络传输中比较慢。

相关推荐
我来整一篇4 分钟前
[mysql] 深分页优化
java·数据库·mysql
Monika Zhang22 分钟前
Memcached 缓存详解及常见问题解决方案
数据库·缓存·memcached
bug总结27 分钟前
如何使用 DBeaver 连接 MySQL 数据库
数据库·mysql
回家路上绕了弯35 分钟前
深入理解 Redis 持久化机制:RDB 与 AOF 的设计与实践
redis
茉莉玫瑰花茶41 分钟前
MySQL 复合查询
数据库·mysql
爱可生开源社区1 小时前
2025 年 7 月《大模型 SQL 能力排行榜》发布
数据库·人工智能·llm
秋难降1 小时前
零基础学习SQL(一)-----关系型数据库DDL和图形化界面工具Datagrip
数据库·mysql·编程语言
Databend1 小时前
Databend 产品月报(2025年7月)
数据库
转身後 默落1 小时前
14.Redis 哨兵 Sentinel
redis·bootstrap·sentinel
战族狼魂2 小时前
通过 Flink 和 CDC 从 Oracle 数据库获取增量数据,并将这些增量数据同步到 MySQL 数据库中
java·数据库·spring boot·mysql·oracle·flink