• Redis是单线程吗?以及为什么使用单线程(Redis 的网络模型)


    Redis 到底是单线程还是多线程

    • 如果仅仅聊Redis的核心业务部分(命令处理),它当然是单线程的。
    • 如果是聊整个Redis,那么答案就是多线程。

    在Redis版本迭代过程中,在两个重要的时间节点上引入了多线程的支持:

    • Redis v4.0:引入多线程异步处理一些耗时较旧的任务,例如异步删除命令unlink
    • Redis v6.0:在核心网络模型中引入 多线程,进一步提高对于多核CPU的利用率

    因此,对于 Redis 的核心网络模型,在 Redis 6.0 之前确实都是单线程。是利用 epoll(Linux系统)这样的 IO 多路复用技术在事件循环中不断处理客户端情况。

    为什么 Redis 选择使用单线程

    • 抛开持久化不谈,Redis是纯 内存操作,执行速度非常快,它的性能瓶颈是网络延迟而不是执行速度,因此多线程并不会带来巨大的性能提升;
    • 多线程会导致过多的上下文切换,带来不必要的开销;
    • 引入多线程会面临线程安全问题,必然要引入线程锁这样的安全手段,实现复杂度增高,而且性能也会大打折扣。

    Redis的单线程模型

    当我们的客户端想要去连接我们服务器,会去先到IO多路复用模型去进行排队,会有一个连接应答处理器,他会去接受读请求,然后又把读请求注册到具体模型中去,此时这些建立起来的连接,如果是客户端请求处理器去进行执行命令时,他会去把数据读取出来,然后把数据放入到client中, clinet去解析当前的命令转化为redis认识的命令,接下来就开始处理这些命令,从redis中的command中找到这些命令,然后就真正的去操作对应的数据了,当数据操作完成后,会去找到命令回复处理器,再由他将数据写出。
    在这里插入图片描述

  • 相关阅读:
    华为OD机试 - 代表团坐车 - 动态规划(Java 2023 B卷 200分)
    支持线程编排的并行框架AsyncTool
    软件测试——基础篇
    面试准备-设计模式-待更新
    Qt 表格导出数据为 excel html csv
    来自2年前端的面经
    读书笔记《蛤蟆先生去看心理医生》
    Linux系统调优详解(十二)——网卡绑定技术
    Java随谈(六)我们真的理解 Java 里的整型吗?
    C++面试/笔试准备,资料汇总
  • 原文地址:https://blog.csdn.net/weixin_45970271/article/details/126163693