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直接操作内存已经很快了并且还有高效的数据结构,比如跳表,哈希进行查询。所以它的性能瓶颈可能只是在网络传输中比较慢。

相关推荐
科技小花2 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸3 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain3 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希3 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神3 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员3 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java4 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿4 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴4 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU4 小时前
三大范式和E-R图
数据库