当前位置: 首页 > 知识库问答 >
问题:

如果Redis是单线程的,怎么会这么快?

孟鸿德
2023-03-14

我目前正在尝试了解Redis的一些基本实现内容。我知道redis是单线程的,我已经偶然发现了以下问题:redis是单线程的,那么它是如何做并发I/O的呢?

但我还是觉得我没理解对。Afaik Redis使用一个单线程使用reactor模式。因此,如果我正确理解了这一点,那么有一个观察者(它处理FDS/传入/传出连接)将要完成的工作委托给它的注册事件处理程序。他们做实际工作并设置。他们的响应作为事件传递给观察者,观察者将响应传递回客户端。但是,如果客户机的请求(R1)需要大约1分钟,会发生什么。另一个客户端创建另一个(快速)请求(R2)。那么--由于redis是单线程的--在R1完成之前,R2不能委托给正确的处理程序,对吗?在html" target="_blank">多线程环境中,您可以在单个线程中启动每个处理程序,因此“主”线程只是接受和响应io连接,而所有其他工作都在自己的线程中执行。

共有1个答案

钱欣悦
2023-03-14

除了Redis中的大多数操作在不到一毫秒几微秒的时间内完成之外,您并没有错过任何东西。长时间运行的操作在执行过程中确实会阻塞服务器。

 类似资料:
  • 本文向大家介绍单线程的 Redis 为什么这么快?相关面试题,主要包含被问及单线程的 Redis 为什么这么快?时的应答技巧和注意事项,需要的朋友参考一下 Redis 有多快?官方给出的答案是读写速度 10万/秒,如果说这是在单线程情况下跑出来的成绩,你会不会惊讶?为什么单线程的 Redis 速度这么快?原因有以下几点: 纯内存操作:Redis 是完全基于内存的,所以读写效率非常的高,当然 Red

  • 代码更清晰,处理逻辑更简单; 不用考虑各种锁的问题,不存在加锁和释放锁的操作,没有因为可能出现死锁而导致的性能问题; 不存在多线程切换而消耗CPU; 无法发挥多核CPU的优势,但可以采用多开几个Redis实例来完善;

  • 本文向大家介绍Redis 为什么是单线程的?相关面试题,主要包含被问及Redis 为什么是单线程的?时的应答技巧和注意事项,需要的朋友参考一下 因为 cpu 不是 Redis 的瓶颈,Redis 的瓶颈最有可能是机器内存或者网络带宽。既然单线程容易实现,而且 cpu 又不会成为瓶颈,那就顺理成章地采用单线程的方案了。 关于 Redis 的性能,官方网站也有,普通笔记本轻松处理每秒几十万的请求。而且

  • 本文向大家介绍redis 的线程模型是怎么样的?相关面试题,主要包含被问及redis 的线程模型是怎么样的?时的应答技巧和注意事项,需要的朋友参考一下 redis 内部使用文件事件处理器 ,这个文件事件处理器是单线程的,所以 redis 才叫做单线程的模型。它采用 IO 多路复用机制同时监听多个 socket,根据 socket 上的事件来选择对应的事件处理器进行处理。 文件事件处理器的结构包含

  • 我肯定误解了整个线程的事情,因为我觉得这个说法令人费解。如果一个程序是单线程的,它如何并发地执行任何操作?如果服务器是单线程的,那么为什么Redis操作是原子的呢? 谁能解释一下这个问题吗?

  • 本文向大家介绍请问,redis为什么是单线程?相关面试题,主要包含被问及请问,redis为什么是单线程?时的应答技巧和注意事项,需要的朋友参考一下 考察点: 因为CPU不是Redis的瓶颈。Redis的瓶颈最有可能是机器内存或者网络带宽。既然单线程容易实现,而且CPU不会成为瓶颈,那就顺理成章地采用单线程的方案了。缺点:服务器其他核闲置。