当前位置: 首页 > news >正文

【Redis】单线程架构

单线程架构

  • 1. 引出单线程模型
  • 2. 为什么单线程还能这么快

Redis 使⽤了单线程架构来实现⾼性能的内存数据库服务

1. 引出单线程模型

在这里插入图片描述

我们已经知道从客⼾端发送的命令经历了:发送命令、执⾏命令、返回结果三个阶段,其中我们重点关注第 2 步。我们所谓的 Redis 是采⽤单线程模型执⾏命令的是指:虽然三个客⼾端看起来是同时要求 Redis 去执⾏命令的,但微观⻆度,这些命令还是采⽤线性⽅式去执⾏的,只是原则上命令的执⾏顺序是不确定的,但⼀定不会有两条命令被同步执⾏,如图 2-3、2-4、2-5 所⽰,可以想象 Redis内部只有⼀个服务窗⼝,多个客⼾端按照它们达到的先后顺序被排队在窗⼝前,依次接受 Redis 的服务,所以两条 incr 命令⽆论执⾏顺序,结果⼀定是 2,不会发⽣并发问题,这个就是 Redis 的单线程执⾏模型。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2. 为什么单线程还能这么快

通常来讲,单线程处理能⼒要⽐多线程差,例如有 10 000 公⽄货物,每辆⻋的运载能⼒是每次200 公⽄,那么要 50 次才能完成;但是如果有 50 辆⻋,只要安排合理,只需要依次就可以完成任务。那么为什么 Redis 使⽤单线程模型会达到每秒万级别的处理能⼒呢?可以将其归结为三点:

  1. 纯内存访问。Redis将所有数据放在内存中,内存的响应时长大约为100纳秒,这就是Redis达到每秒万级别访问的重要基础
  2. 非阻塞IO。Redis采用epoll 作为 IO多路复用技术的视线,再加上Redis自身的事件处理模型将 epoll 中的连接、读写、关闭都转换为事件,不在网络IO上浪费过多的时间
  3. 单线程避免了线程切换和竞态产生的消耗。单线可以简化数据结构和算法的实现,让程序模型更简单;其次多线程避免了在线程竞争同一份共享数据时带来的切换和等待消耗。

在这里插入图片描述
虽然单线程给 Redis 带来很多好处,但还是有⼀个致命的问题:对于单个命令的执⾏时间都是有要求的。如果某个命令执⾏过⻓,会导致其他命令全部处于等待队列中,迟迟等不到响应,造成客⼾端的阻塞,对于 Redis 这种⾼性能的服务来说是⾮常严重的,所以 Redis 是⾯向快速执⾏场景的数据库。


http://www.mrgr.cn/news/5256.html

相关文章:

  • Python知识点:如何使用Flask与AWS Lambda构建无服务器应用
  • 深入解析fs.ReadStream:Node.js中的文件读取流利器
  • spring中事务介绍
  • 得物App白屏优化系列|网络篇
  • 详解Linux命令--netstat
  • 代驾系统源码开发中的用户体验优化:从设计到实现的全方位解析
  • 观测云的安全监控策略:Prometheus 生态的深度集成
  • MySQL中的约束
  • Linux设备驱动节点里的bind与unbind
  • 工业物联网(IIOT)的定义、示例及关键技术
  • 深度学习中常用参数解释
  • Android笔试面试题AI答之Kotlin偏门考点总结
  • 【C++】深入解析C/C++内存管理:new与delete的使用及原理
  • SQL手工注入漏洞测试(MongoDB数据库)
  • 深入探讨量子计算领域的最新进展及其对社会经济的影响
  • EasyCVR视频汇聚技术赋能智慧煤矿:车载设备接入方案助力实时监控与远程监管
  • 软件测试面试题总结(含答案解析+文档)
  • Leetcode JAVA刷刷站(74)搜索二维矩阵
  • Vue的生命周期了解
  • C#实现数据采集系统-数据反写(1)MQTT订阅接收消息