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

相关推荐
自信的小螺丝钉23 分钟前
Leetcode 146. LRU 缓存 哈希表 + 双向链表
leetcode·缓存·散列表
牛奶咖啡132 小时前
关系数据库MySQL的常用基础命令详解实战
数据库·mysql·本地远程连接到mysql·创建mysql用户和密码·修改mysql用户的密码·设置mysql密码的使用期限·设置和移除mysql用户的权限
ANYOLY3 小时前
Redis 面试宝典
数据库·redis·面试
鲲志说3 小时前
数据洪流时代,如何挑选一款面向未来的时序数据库?IoTDB 的答案
大数据·数据库·apache·时序数据库·iotdb
没有bug.的程序员3 小时前
MVCC(多版本并发控制):InnoDB 高并发的核心技术
java·大数据·数据库·mysql·mvcc
脑花儿5 小时前
ABAP SMW0下载Excel模板并填充&&剪切板方式粘贴
java·前端·数据库
SELSL5 小时前
SQLite3的API调用实战例子
linux·数据库·c++·sqlite3·sqlite实战
洲覆5 小时前
Redis 核心数据类型:从命令、结构到实战应用
服务器·数据库·redis·缓存
傻啦嘿哟5 小时前
Python SQLite模块:轻量级数据库的实战指南
数据库·python·sqlite
维尔切5 小时前
HAProxy 负载均衡器
linux·运维·数据库·负载均衡