Redis 是单线程的正确理解

article/2025/6/18 13:30:06

一、为什么Redis是单线程的

1️⃣官方答案
因为 Redis 是基于内存的操作,CPU不是 Redis 的瓶颈。Redis 的瓶颈最有可能是机器内存的大小或者网络带宽。既然单线程容易实现,而且 CPU 不会成为瓶颈,那就顺理成章地采用单线程的方案了。

2️⃣性能指标
关于 Redis 的性能,官方网站也有,普通笔记本轻松处理每秒几十万的请求。

3️⃣详细原因

  1. 不需要各种锁的性能消耗
    Redis 的数据结构并不全是简单的 Key-Value,还有 list,hash 等复杂的结构。这些结构有可能会进行很细粒度的操作,比如在很长的列表后面添加一个元素,在 hash 当中添加或者删除一个对象。这些操作可能就需要加非常多的锁,导致的结果是同步开销大大增加。
    总之,在单线程的情况下,代码更清晰,处理逻辑更简单,不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗,不存在多进程或者多线程导致的切换而消耗 CPU。
  2. 单线程多进程的集群方案
    单线程的威力实际上非常强大,每核效率也非常高。多线程自然是可以比单线程有更高的性能上限,但是在今天的计算环境中,即使是单机多线程的上限也往往不能满足需要了,需要进一步摸索的是多服务器集群化的方案,这些方案中多线程的技术照样是用不上的。所以单线程、多进程的集群不失为一个时髦的解决方案。
  3. CPU 消耗
    采用单线程,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换而消耗 CPU。但是如果 CPU 成为 Redis 瓶颈,或者不想让服务器其他 CPU 核闲置,那怎么办?
    可以考虑多起几个 Redis 进程,Redis 是 key-value 数据库,不是关系数据库,数据之间没有约束。只要客户端分清哪些 key 放在哪个 Redis 进程上就可以了。

二、Redis的单线程理解

Redis 客户端对服务端的每次调用都经历了发送命令,执行命令,返回结果三个过程。其中执行命令阶段,由于 Redis 是单线程来处理命令的,所有到达服务端的命令都不会立刻执行,所有的命令都会进入一个队列中,然后逐个执行,并且多个客户端发送的命令的执行顺序是不确定的,但是可以确定的是不会有两条命令被同时执行,不会产生并发问题,这就是 Redis 的单线程基本模型。

Redis 服务器通过 socket (套接字)与客户端或其他 Redis 服务器进行连接,而文件事件就是服务器对 socket 操作的抽象。服务器与客户端或其他服务器的通信会产生相应的文件事件,而服务器通过监听并处理这些事件来完成一系列网络通信操作。

Redis 基于 Reactor 模式开发了自己的网络事件处理器——文件事件处理器,文件事件处理器使用 I/O 多路复用程序来同时监听多个 socket,并根据 socket 目前执行的任务来为 socket 关联不同的事件处理器。当被监听的 socket 准备好执行连接应答、读取、写入、关闭等操作时,与操作相对应的文件事件就会产生,这时文件事件处理器就会调用 socket 之前已关联好的事件处理器来处理这些事件。文件事件处理器的构成:

注意:其中 I/O 多路复用程序通过队列向文件事件分派器传送 socket。

I/O多路复用技术

Redis 采用网络 I/O 多路复用技术,来保证在多连接的时候系统的高吞吐量。关于 I/O 多路复用(又被称为“事件驱动”),首先要理解的是,操作系统为你提供了一个功能,当你的某个 socket 可读或者可写的时候,它可以给你一个通知。这样当配合非阻塞的 socket 使用时,只有当系统通知我哪个描述符可读了,我才去执行 read 操作,可以保证每次 read 都能读到有效数据而不做纯返回 -1 和 EAGAIN 的无用功,写操作类似。

操作系统的这个功能是通过 select/poll/epoll/kqueue 之类的系统调用函数来实现,这些函数都可以同时监视多个描述符的读写就绪状况,这样,多个描述符的 I/O 操作都能在一个线程内并发交替地顺序完成,这就叫 I/O 多路复用。多路—指的是多个 socket 连接,复用—指的是复用同一个 Redis 处理线程。多路复用主要有三种技术:select,poll,epoll。epoll 是最新的也是目前最好的多路复用技术。

采用多路 I/O 复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络 I/O 的时间消耗),且 Redis 在内存中操作数据的速度非常快,也就是说内存内的操作不会成为影响 Redis 性能的瓶颈,基于这两点 Redis 具有很高的吞吐量。

三、单线程的 Redis 为何高并发快

Redis 利用队列技术将并发访问变为串行访问,消除了传统数据库串行控制的开销。

1️⃣Redis 的高并发和快速原因

  1. Redis 是基于内存的,内存的读写速度非常快。
  2. Redis 是单线程的,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换而消耗 CPU,不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗。
  3. Redis 使用多路复用技术,可以处理并发的连接。非阻塞 IO 部实现采用 epoll,采用了 epoll+自己实现的简单的事件框架。epoll 中的读、写、关闭、连接都转化成了事件,然后利用 epoll 的多路复用特性,绝不在 IO 上浪费一点时间。
  4. 数据结构简单,对数据操作也简单,Redis 中的数据结构是专门进行设计的。
  5. Redis 直接自己构建了 VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。

2️⃣单进程单线程弊端
无法发挥多核 CPU 性能,不过可以通过在单机开多个 Redis 实例来完善。

3️⃣Redis高并发总结

  1. Redis 是纯内存数据库,一般都是简单的存取操作,线程占用的时间很多,时间的花费主要集中在 IO 上,所以读取速度快。
  2. Redis 使用的是非阻塞 IO。IO 多路复用,使用了单线程来轮询描述符,将数据库的开、关、读、写都转换成了事件,减少了线程切换时上下文的切换和竞争。
  3. Redis 采用了单线程的模型,保证了每个操作的原子性,也减少了线程的上下文切换和竞争。
  4. Redis 全程使用 hash 结构,读取速度快,还有一些特殊的数据结构,对数据存储进行了优化,如压缩表,对短数据进行压缩存储,再如,跳表,使用有序的数据结构加快读取的速度。
  5. Redis 采用自己实现的事件分离器,效率比较高,内部采用非阻塞的执行方式,吞吐能力比较大。

四、常见疑问解答

1️⃣为什么不采用多进程或多线程处理?

①多线程处理可能涉及到锁。
②多线程处理会涉及到线程切换而消耗 CPU。

2️⃣单线程处理的缺点?

①耗时的命令会导致并发的下降,不只是读并发,写并发也会下降。
②无法发挥多核 CPU 性能,不过可以通过在单机开多个 Redis 实例来完善。

3️⃣Redis 不存在线程安全问题

Redis 采用了线程封闭的方式,把任务封闭在一个线程,自然避免了线程安全问题,不过对于需要依赖多个 Redis 操作(即多个 Redis 操作命令)的复合操作来说,依然需要锁,而且有可能是分布式锁。


http://chatgpt.dhexx.cn/article/BxfLcD4N.shtml

相关文章

Python单线程/多线程

Python里的多线程是假的多线程,不管有多少核,同一时间只能在一个核中进行操作! 利用Python的多线程,只是利用CPU上下文切换的优势,看上去像是并发,其实只是单线程。 import threading import timedef tes…

为什么 Redis 是单线程的

文章目录 3.6 为什么 Redis 是单线程的3.6.1 Redis的单线程理解3.6.2 单线程的 Redis 为何高并发快 3.6 为什么 Redis 是单线程的 参考地址:https://blog.csdn.net/ChineseSoftware/article/details/122562476 官方答案 因为 Redis 是基于内存的操作,CP…

Python的单线程和多线程

1.发展背景 2.进程和线程的区别 线程是程序执行的最小单位,而进程是操作系统分配资源的最小单位;一个进程由一个线程组成,线程是一个进程中代码的不同执行路线;进程之间相互独立,但同一进程下的各个线程之间共享程序的…

JavaNIO——单线程(笔记)

文章目录 一、 三大组件1.1 Channel & Buffer1.2 Selector 二、 ByteBuffer字节缓存2.1 结构2.2 堆内存与直接内存2.3 读与写2.4 Scattering Reads与Gathering Writes2.5 简单处理黏包与半包 三、FileChannel文件编程3.1 读取3.2 写入3.3 关闭3.4 位置3.5 大小3.6 强制写入…

单线程简介

单线程顾名思义,就是只有一个线程,默认情况下,系统为应用程序分配一个主线程,该线程执行程序中以Main方法开始和结束的代码。线程具有生命周期,它包含3个状态,分别为出生状态、就绪状态和运行状态。 出生状…

小米更新显示非官方rom_MIUI官改篇对比分析-极光ROM-台湾W大-星空未来-其他官改官网...

说起安卓刷机,最有趣味性的就是小米手机了,能解锁BL,能ROOT,基本成功刷机 主流机型,而小米的开源也确确实实得到了认可。小米刷机基本分出2条线路,一个 是第三方ROM,一条是官方修改版ROM,今天ROM乐园小编就和大家分析下以下常 见的几个官方修改版ROM:极光ROM-台湾W大-…

安卓rom制作教程_MIUI官改篇对比分析-极光ROM-台湾W大-星空未来-其他官改官网

说起安卓刷机,最有趣味性的就是小米手机了,能解锁BL,能ROOT,基本成功刷机 主流机型,而小米的开源也确确实实得到了认可。小米刷机基本分出2条线路,一个 是第三方ROM,一条是官方修改版ROM,今天ROM乐园小编就和大家分析下以下常 见的几个官方修改版ROM:极光ROM-台湾W大-…

如何将以前wm手机所备份的bkg文件导入android手机,【极光ROM】-【三星S20(国行/港版/台版/韩版/美版) G981X-高通865】-【V5.0 Android-Q-TI8】...

● 支持机型: ● G9810(国行S20/港版S20/台版S20) ● G981N(韩版S20) ● G981U(美版S20) ● 注意事项: 1、ROM为卡刷包,请先刷入TWRP后再进行刷机,TWRP在刷机工具中获取。 2、刷本ROM前请先使用ODIN刷入官方2.5的底包4件套(TH*系列…

香港 三星 android6.0,【极光ROM】-【三星NOTE20高通全系列(国行/港版/台版/韩版/美版) N98XX】-【V6.0 Android-R-UC1】...

● 支持机型: ● NOTE20系列国行/港版/台版(N9810/N9860) ● NOTE20系列韩版(N981N/N986N) ● NOTE20系列美版(N981U/N986U) ● 写在前面: 1、刷机以后可能出现的问题:安全性降低、失去保修、KNOX物理熔断、无法使用三星PAY、无法支持支付宝指…

三星note10 android q,【极光ROM】-【三星NOTE10/NOTE10+/5G N97XX-855 国行/港行/美版】-【V10.0 Android-Q-TK1】...

● 支持机型: ● N970X(国行/港版/美版N10) ● N975X(港版/台版/美版N10+) ● N976X(国行/美版N10+5G) ● 写在前面: 1、刷机以后可能出现的问题:安全性降低、失去保修、KNOX物理熔断、无法使用三星PAY、无法支持支付宝指纹、无法连接三星手表等问题。 2、刷机后开机会提示红…

三星S7edge刷极光ROM的总结_我是亲民_新浪博客

因为极光ROM的众多好处,所以在中秋节前,下决心刷了一次,小小总结一下,以后备用。 [ROM特性] 系统: 基于G9350国行官方最新G9350ZCU2APD1底包完美移植。 完美ROOT权限,自带SUPERSU管理程序。 精简官方大量无…

香港 三星 android6.0,【极光ROM】-【三星S20(国行/港版/台版/韩版/美版) G981X-高通865】-【V6.0 Android-Q-TJA】...

● 支持机型: ● G9810(国行S20/港版S20/台版S20) ● G981N(韩版S20) ● G981U(美版S20) ● 注意事项: 1、ROM为卡刷包,请先刷入TWRP后再进行刷机,TWRP在刷机工具中获取。 2、刷本ROM前请先使用ODIN刷入官方2.5的底包4件套(TH*系列…

三星android rom开发者,三星s10刷机包安卓10(极光AuroraROM 13.0)

三星s10是三星的上一代发烧级旗舰系列,其优秀的屏幕和良好的体验让各位用户都沉浸其中,针对中国做出了国行优化的系统更是让中国用户拍手叫好,现在就来给大家分享一款第三方开发的极光AuroraROM,祝大家刷机愉快 刷机前注意 1、刷机以后可能将会失去保修、无法使用三星PAY、…

三星S7edge刷极光ROM的总结

因为极光ROM的众多好处,所以在中秋节前,下决心刷了一次,小小总结一下,以后备用。 [ROM特性]系统: 基于G9350国行官方最新G9350ZCU2APD1底包完美移植。完美ROOT权限,自带SUPERSU管理程序。精简官方大量无用…

IDEA、MySQL、SQLyog安装教程

IDEA、MySQL、SQLyog安装教程 IDEA安装以及jdk环境变量设置 从官网上根据操作系统下载对应IntelliJ IDEA版本下载完成后,双击安装程序,进入安装界面,点击Next更改安装目录或保留默认安装目录后,点击Next根据本地操作系统的版本选…

<SQL编程工具MySQL、SQLyog安装及环境配置教程>——《SQL》

目录 1.MySQL安装: 1.1 MySQL下载安装: 1.2 MySQL环境变量配置: 2.SQLyog安装: 2.1 SQLyog下载安装: 3.写在最后的话: 后记:●由于作者水平有限,文章难免存在谬误之处&…

mysql+sqlyog的超详细完整安装+数据库基础知识

目录 一、安装mysql下载解压添加环境变量创建文件启动mysql安装mysql 二、sqlyog安装sqlyog下载 三 补充3.1 常用的数据库命令3.2 基本操作3.2.1 常用的sql语言命令3.2.2 sql语句示例3.2.3常用函数表关系分类一对多多对多关系多表查询的推荐方式 SQL语言在功能上主要分为如下3大…

mysql yog连接教程,MySQL与sqlyog安装教程图文详解

1. MySQL1.1 MySQL安装 mysql-5.5.27-winx64下载 (1)欢迎安装 (2)协议接受 (3)安装模式选择 Typical:表示一般常用的组件都会被安装,默认情况下安装到C:\Program Files\MySQL\MySQL Server 5.5\下。 Complete:表示会安装所有的组件。此套件会…

SQLyog安装过程

1. 2.next,同意next,next,设置安装目录、安装,next,finish 3. ​注册名:luoye2562 ​ 注册码: 59adfdfe-bcb0-4762-8267-d7fccf16beda ​( ​ ​Professional 版本: 注…

【Java开发环境配置】6-SQLyog安装教程(26)

一.SQLyog简介: SQLyog 是一个快速而简洁的图形化管理MySQL数据库的工具,它能够在任何地点有效地管理你的数据库,由业界著名的Webyog公司出品。使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库。 二.SQLyog下载: 下载地址…