Redis 到底是单线程还是多线程
- 如果仅仅聊Redis的核心业务部分(命令处理),它当然是单线程的。
- 如果是聊整个Redis,那么答案就是多线程。
- Redis v4.0:引入多线程异步处理一些耗时较旧的任务,例如异步删除命令unlink
- Redis v6.0:在核心网络模型中引入 多线程,进一步提高对于多核CPU的利用率
为什么 Redis 选择使用单线程
- 抛开持久化不谈,Redis是纯 内存操作,执行速度非常快,它的性能瓶颈是网络延迟而不是执行速度,因此多线程并不会带来巨大的性能提升;
- 多线程会导致过多的上下文切换,带来不必要的开销;
- 引入多线程会面临线程安全问题,必然要引入线程锁这样的安全手段,实现复杂度增高,而且性能也会大打折扣。
文章图片
推荐阅读
- Redis|从底层看 Redis 的五种数据类型
- Mysql优化|Mysql-索引优化
- java|创作365天纪念日
- java|甲方不让用开源【监控软件】(大不了我自己写一个)
- 生产系统中的机器学习工程|基于 Docker 快速使用远程(云)数据库
- TiDB|构建实时数仓 - 当 TiDB 偶遇 Pravega
- redis|Redis的使用场景和注意事项
- 缓存|Redis的应用场景
- redis|redis 了 什么地方用到_项目中redis使用场景