Redis 是单线程还是多线程

我们平时看到介绍 Redis 的文章,都会说 Redis 是单线程的。但是我们学习的时候,比如 Redis 的 bgsave 命令,它的作用是在后台异步保存当前数据库的数据到磁盘,那既然是异步了,肯定是由别的线程去完成的,这怎么还能说 Redis 是单线程的呢?

其实通常说的 Redis 是单线程,主要是指 Redis 对外提供键值存储服务的主要流程,即网络 IO 和键值对读写是由⼀个线程来完成的。除此外 Redis 的其他功能,比如持久化、 异步删除、集群数据同步等,是由额外的线程执⾏的。在这一点上 Node 也是一样的,一般提到 Node 也是单线程的,但其实 Node 只有一个主线程是单线程,其他异步任务则由其他线程完成。这样做的原因是防止有同步代码阻塞,导致主线程被占用后影响后续的程序代码执行。

因此,严格地说 Redis 并不是单线程。但是我们⼀般把 Redis 称为单线程高性能,这样显得 Redis 更强一些。

这里需要注意一个问题,我们所说的Redis的单线程,不是指Redis程序真的只会有一个线程。这里所说的单线程,指的是Redis处理客户端发来的数据操作请求(增删改查),只会使用一个线程去执行。但是实际上,Redis在执行其他操作的时候,可能会开启多个进程或线程,比如说持久化。Redis执行BGSAVE指令,进行快照持久化时,就会fork出一个子进程,然后子进程去创建快照,完成持久化操作。

为什么Redis使用单线程?

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

上面的解释不是很好理解,我就简单说一说我自己的理解吧。我们知道,Redis将数据存放在内存当中,这也就意味着,Redis在操作数据时,不需要进行磁盘I/O。磁盘I/O是一个比较耗时的操作,所以对于需要进行磁盘I/O的程序,我们可以使用多线程,在某个线程进行I/O时,CPU切换到当前程序的其他线程执行,以此减少CPU的等待时间。而Redis直接操作内存中的数据,所以使用多线程并不能有效提升效率,相反,使用多线程反倒会因为需要进行线程的切换而降低效率。

除此之外,使用多线程的话,多个线程间进行同步,保证线程的安全,也是需要开销的。尤其是Redis的数据结构都是一些实现较为简单的集合结构,若使用多线程,将会频繁地发生线程冲突,线程的竞争频率较高,反倒会拖慢Redis的响应速度。

综上所述,Redis为了保持简单和高效,自然而然地就使用了单线程。

Redis如何提高CPU使用率

前面也提过,现在的CPU一般都有多个核心,每个核心可以单独执行。Redis处理客户端请求使用单线程,那么自然而然,无法将CPU的所有核心都占用,也就造成了资源的浪费。而解决的方式也比较简单,我们可以在同一个服务器上开启多个Redis程序,每个Redis程序使用不同的端口,相互独立,以此提高CPU的使用率。而这多个Redis程序可以配置成主从节点,共同为一个程序服务,也可以相互独立,服务于多个程序。

参考

Redis 是单线程还是多线程相关推荐

  1. Redis 属于单线程还是多线程?不同的版本有什么区别?

    Redis 是普及率最高的技术之一,同时也是面试中必问的一个技术模块,所以从今天开始我们将从最热门的 Redis 面试题入手,更加深入的学习和了解一下 Redis. 我们本文的面试题是 Redis 属 ...

  2. Redis是单线程还是多线程问题

    在学习redis的过程中,很多文章都说redis是单线程,但在官方给出的说明中显示,redis6.0已经引入了多线程,对此我找了许多文档,将学习过程整理记录下来. 1.Redis单线程 在一开始的时候 ...

  3. redis是单线程还是多线程?

    1.Redis单线程 在一开始的时候,Redis采用的是单线程模型,因为Redis是一个基于内存的数据库,将所有的数据放入内存,所以使用单线程的操作效率是最高的,多线程会上下文切换消耗大量时间,对于内 ...

  4. Redis 5.0.8+常见面试题(单线程还是多线程、先更新缓存还是数据库、雪崩穿透击穿解决办法...)

    Redis 6.0 保姆级教程(含微服务案例与完整面试题):https://www.yuque.com/yuxuandmbjz/redis Redis是单线程还是多线程 ?为什么这么设计 ? Redi ...

  5. 程序员过关斩将--请不要误会redis 6.0 的多线程

    " 你对redis的单线程是不是有点误会? " 你对redis 6.0的多线程是不是也有点误会? " redis多线程一定可以提高性能吗? redis官方刚刚发布的6.0 ...

  6. Redis新版本发布,你还认为Redis是单线程?

    Redis从单线程到多线程的转变 Redis简介 Redis单线程时代 `"单线程"`的Redis为什么会这么快? Redis的瓶颈 6.0版本后的Redis线程问题 redis的 ...

  7. 单线程多线程_面试系列 redis为什么快amp;单线程amp;多线程

    redis为什么这么快 C语言实现,执行速度快 纯内存操作,数据读写在内存中,异步持久化到磁盘 丰富和高效的数据结构 基于非阻塞的I/O多路复用机制 单线程避免了上下文切换 Redis单线程 redi ...

  8. Redis单线程和多线程

    Redis单线程 Reids是单线程! Reids是单线程! Reids是单线程! Redis架构模型:Redis 基于 Reactor 模式来设计开发了自己的一套高效的事件处理模型 ,即文件事件处理 ...

  9. Redis新特性、剖析线程模型(单线程与多线程)

    一. Redis6.0 新特性 1. 多线程IO redis6.0引入多线程IO,只是用来处理网络数据的读写和协议的解析,而执行命令依旧是单线程,所以不需要去考虑set/get.事务.lua等的并发问 ...

最新文章

  1. python周末列表的表示形式合并_Python 列表合并题
  2. msicuu.exe (msizap.exe),程序的作用
  3. PostgreSQL 电商业务(任意维度商品圈选应用) - json包range数组的命中优化 - 展开+索引优化...
  4. 任务计划cron、服务管理工具chkconfig/systemctl
  5. Netty4服务端和客户端实现
  6. mysql索引红黑联盟_MySQL索引
  7. 生活质量衡量系统_数据质量与数据质量八个维度指标
  8. java 多态,接口,抽象类的认识
  9. 不用去验血,一查就能知道自己缺啥,一定要收好
  10. 自学python需要安装什么-终于明白python需要学什么
  11. SQL学习笔记之游标
  12. 使用struts框架的简单jsp登录页面
  13. [3D数学基础:图形与游戏开发]读书笔记 第12章(几何图元直线、AABB、球圆、平面、三角形、多边形)
  14. python两台电脑文件传输_两台电脑怎么互相连接传送文件?
  15. 这么有料的福利,你还不赶紧关注一波吗?(代码合集)
  16. 浅谈车联网与大数据分析
  17. P4414 [COCI2006-2007#2] ABC
  18. 详讲全排列算法,及解决数字搭积木问题
  19. linux中浏览器连不上网络,在Linux中修复Firefox浏览器“Network Protocol Error”错误的方法...
  20. 关于ChatGPT的一切;CUDA入门之矩阵乘;PyTorch 2.0发布|AI系统前沿动态

热门文章

  1. XQ-VNC ---超级好用的免费安卓VNC工具
  2. 用Python帮女神爬取电影后,我终于不用做舔狗了
  3. solor快速_solr:快速开始
  4. AdsPower:80W+跨境人的首选,您的跨境电商账号安全管理专家
  5. 将linux系统装入U盘,制作便携式linux系统。
  6. GeoServer发布图层遇到的几个雷点及解决方案
  7. dequeueReusableCellWithIdentifie…
  8. 做个小本生意怎么赚钱
  9. jquery中class选择器的用法
  10. Python函数独立星号(*)分隔的命名关键字参数