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 的核心功能相比于其它关系型数据库更简单,任务更少

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

相关推荐
寂寞旅行2 小时前
向量数据库Milvus的使用
数据库·milvus
闻哥3 小时前
Redis事务详解
java·数据库·spring boot·redis·缓存·面试
道亦无名3 小时前
aiPbMgrSendAck
java·网络·数据库
面向对象World6 小时前
正点原子Mini Linux 4.3寸800x480触摸屏gt115x驱动
linux·服务器·数据库
dinga198510266 小时前
mysql之联合索引
数据库·mysql
微风中的麦穗7 小时前
【SQL Server 2019】企业级数据库系统—数据库SQL Server 2019保姆级详细图文下载安装完全指南
大数据·数据库·sqlserver·云计算·个人开发·运维必备·sqlserver2019
zjttsh8 小时前
MySQL加减间隔时间函数DATE_ADD和DATE_SUB的详解
android·数据库·mysql
顾北128 小时前
SpringCloud 系列 04:Gateway 断言 / 过滤器 / 限流 一站式落地指南
java·开发语言·数据库
禹凕8 小时前
MYSQL——基础知识(NULL 值处理)
数据库·mysql
码云数智-大飞8 小时前
SQL Server 无法启动?常见原因及详细解决方法指南
数据库