Redis(三)单线程架构介绍

前文已经介绍了,Redis 是使用单线程架构来实现高性能的数据库服务;但实际上 Redis 虽然只使用一个线程来处理所有命令请求,但Redis 服务器内部并不是只有一个线程;处理命令的所有请求的那个线程,称作核心主线程,还有另外多个线程用来处理网络 IO 服务。
宏观上,客户端"并发"向 Redis 服务端发送请求

多个请求到达服务器,由于处理请求是单线程的,所以这多个请求会根据到来先后顺序在 Redis 提供的等待队列上排队,由核心主线程一个个取出进行处理。
微观上,Redis 服务器实际上是串行执行这些命令的,也不存在线程安全问题

重要问题:Redis 是单线程的,为什么和其它关系型数据库相比,还能这么快?

1、Redis 是纯内存访问的。

Redis 把所有的数据都存放在内存中,而内存的响应时长很快(约为100 ns),这也是 Redis 可以达到每秒万级别访问的重要基础。

2、Redis 使用 epoll 进行 IO 多路复用,不会在网络 IO 上浪费过多时间

Redis 把 epoll 中的各种操作都转换为事件

基于 epoll 的 IO 多路复用,可以让一个线程管理多个套接字上的事件,通过 epoll 本身的回调和事件通知机制,让线程处理命令,属于非阻塞式 IO,节约了时间。

3、 单线程处理命令机制避免了线程切换、竞态导致的额外消耗

Redis 的所有命令请求都是在服务端的核心主线程上进行处理的,既简化了算法与数据结构的实现,又避免了多线程竞争同一份资源以及多线程切换的消耗。

(Redis 的每个基本操作都是短平快的,就是简单操作一下内存,不是很吃 CPU,多线程用处也不大)

4、Redis 的核心功能相比于其它关系型数据库更简单,任务更少

其它关系型数据库,对于数据的增删查改都有更为复杂的功能支持*(比如数据库的各种索引、约束)*,这样势必会导致更多的开销。

相关推荐
HackTwoHub3 小时前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
l1t3 小时前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK3 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)3 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
callJJ4 小时前
Spring Data Redis 两种编程模型详解:同步 vs 响应式
java·spring boot·redis·python·spring
S1998_1997111609•X4 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
KmSH8umpK5 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
0xDevNull6 小时前
Linux 中 Nginx 代理 Redis 的详细教程
redis·后端
BU摆烂会噶6 小时前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
l1t7 小时前
DeepSeek总结的DuckLake 入门
数据库