Redis是单线程还是多线程?

Redis通常被称为单线程模型,其实它在网络IO和键值对读写上是单线程,但其他如持久化和集群模块采用多线程。Redis6.0引入了多线程处理网络请求,但数据读写仍保持单线程,避免并发问题。采用I/O多路复用技术提高I/O利用率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Redis是单线程还是多线程?
知乎上的一篇文章写得比较好,记录一下 Redis是单线程还是多线程?

  1. 目前所说的Redis单线程,指的是"其网络IO和键值对读写是由一个线程完成的",也就是说,Redis中只有网络请求模块和数据操作模块是单线程的。而其他的如持久化存储模块、集群支撑模块等是多线程的。
    在提升I/O利用率这个方面上,Redis并没有采用多线程技术,而是选择了I/O多路复用技术。
  2. Redis 6.0中的多线程,也只是针对处理网络请求过程采用了多线程,而数据的读写命令,仍然是单线程处理的。
    Redis 6.0 只有在网络请求的接收和解析,以及请求后的数据通过网络返回时,使用了多线程。而数据读写操作还是由单线程来完成的,所以,这样就不会出现并发问题了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值