为什么 Redis 是单线程的

article/2025/6/18 15:00:10

文章目录

      • 3.6 为什么 Redis 是单线程的
        • 3.6.1 Redis的单线程理解
        • 3.6.2 单线程的 Redis 为何高并发快

3.6 为什么 Redis 是单线程的

参考地址:https://blog.csdn.net/ChineseSoftware/article/details/122562476

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

  • 性能指标

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

  • 详细原因

1)不需要各种锁的性能消耗
Redis 的数据结构并不全是简单的 Key-Value,还有 list,hash 等复杂的结构。这些结构有可能会进行很细粒度的操作,比如在很长的列表后面添加一个元素,在 hash 当中添加或者删除一个对象。这些操作可能就需要加非常多的锁,导致的结果是同步开销大大增加。
总之,在单线程的情况下,代码更清晰,处理逻辑更简单,不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗,不存在多进程或者多线程导致的切换而消耗 CPU。

2)单线程多进程的集群方案
单线程的威力实际上非常强大,每核效率也非常高。多线程自然是可以比单线程有更高的性能上限,但是在今天的计算环境中,即使是单机多线程的上限也往往不能满足需要了,需要进一步摸索的是多服务器集群化的方案,这些方案中多线程的技术照样是用不上的。所以单线程、多进程的集群不失为一个时髦的解决方案。

3)CPU 消耗
采用单线程,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换而消耗 CPU。但是如果 CPU 成为 Redis 瓶颈,或者不想让服务器其他 CPU 核闲置,那怎么办?
可以考虑多起几个 Redis 进程,Redis 是 key-value 数据库,不是关系数据库,数据之间没有约束。只要客户端分清哪些 key 放在哪个 Redis 进程上就可以了。

3.6.1 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 具有很高的吞吐量。

3.6.2 单线程的 Redis 为何高并发快

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

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

无法发挥多核 CPU 性能,不过可以通过在单机开多个 Redis 实例来完善。

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

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

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

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

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

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

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

4️⃣高性能的服务器一定是多线程的?多线程一定比单线程效率高?

Redis将所有的数据全部放在内存中,使用单线程去操作效率比较高,对于多线程,CPU 会有上下文切换,这种操作耗时,对于内存系统来说,没有上下文切换,效率相对是高的。

Redis使用单进程的模式来处理客户端的请求,对大部分事件的响应都是通过 epol l函数的加强封装,Redis 的实际处理速度依靠主进程的执行效率,epoll 可以显著提高程序在大量并发连接中系统的 CPU 利用率

 
 


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

相关文章

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下载: 下载地址…

数据库可视化工具(SQLyog安装教程)

SQLyog安装教程 一、软件下载二、操作步骤 1.数据库安装成功了以后,可以通过Windows 命令提示符(cmd.exe)对数据进行增删改查。但这样操作数据,不仅很麻烦,而且看得也很头晕。   2.利用数据库可视化工具,…

SQLyog Ultimate软件安装教程

目录 一、软件介绍 二、软件下载 三、软件安装 (1)首先下载云盘中的SQLyog-12.0.8-0.x64.exe (2)双击执行SQLyog-12.0.8-0.x64.exe文件,点击OK (3)选择下一步 (4)勾选…