Redis 的速度为什么这么快

这里的速度快,Redis 的速度快是与 MySQL 等数据库相比较的,与直接操作内存数据相比,Redis 还是略有逊色。

Redis 是一个单线程模型,为什么比其他的多线程程序还要快,原因有以几点:

1、访问的对象不同

Redis 访问内存,而其他数据库是直接访问硬盘,操作内存数据一定比操作硬盘数据要来得更快。

2、Redis 的操作通常都是 "短平快"

所谓 "短平快",就是 Redis 的操作通常只是一些简单的操作,相比于其他数据库的复杂操作,Redis 的操作所消耗的资源更少,速度也是更快的。

3、Redis 是单线程模型

这里的单线程,不是 Redis 整个程序只有一个线程,而是只使用了一个线程来处理指令,在处理网络 IO 时使用的也是多线程。

使用单线程来处理指令,就能避免线程之间的竞争,从而就没有线程之间的竞争开销。

4、处理网络 IO 时,使用了IO多路复用的机制

上面说了,Redis 在处理网络请求时使用的是多线程模式,也就是一次能接收多个请求,但引入 IO多路复用(如 epoll 等机制)后,就能只使用较少的线程去处理多数的请求(前提是这些请求是不频繁的,线程大多数时间都在等)。

相关推荐
这个DBA有点耶16 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶18 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技18 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend19 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence1 天前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说2 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils2 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend2 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶2 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung2 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql