当前位置:网站首页>Redis是单线程吗?以及为什么使用单线程(Redis 的网络模型)
Redis是单线程吗?以及为什么使用单线程(Redis 的网络模型)
2022-08-06 09:35:00 【星辰与晨曦】
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中找到这些命令,然后就真正的去操作对应的数据了,当数据操作完成后,会去找到命令回复处理器,再由他将数据写出。
边栏推荐
猜你喜欢

昼夜双色导航主题模板 WordPress导航模板

国内自媒体宣发.多媒体发稿的优势

ELT.zip 】 【 OpenHarmony chew club - the methodology of academic research paper precipitation series

nuxt中使用字体图标,解决第一次可以加载出来,刷新页面图标消失的问题

【OpenCV】 人脸识别

【机器学习】贝叶斯分类器

响应式建筑工程集团公司类网站织梦模板(自适应手机端)

聊聊mysql唯一索引的哪些坑,为什么还是产生重复数据?

【ELT.ZIP】OpenHarmony啃论文俱乐部——学术科研方法论沉淀辑
![Web version Xshell supports FTP connection and SFTP connection [Detailed tutorial] Continue from the previous article](/img/30/c9d087554bb028582c494098664275.png)
Web version Xshell supports FTP connection and SFTP connection [Detailed tutorial] Continue from the previous article
随机推荐
18 days (link aggregation of configuration, the working process of the VRRP, IPV6 configuration)
Hdu2022 Multi-School Training (5) BBQ
回头再看ResNet——深度学习史上的关键一步
Linux - several ways to install MySQL
根据轮廓创建旋转框和椭圆
Day and night double-color navigation WordPress theme template navigation template
LinkedList 是如何完成添加的?
集成学习进阶
【TensorFlow&PyTorch】loss损失计算
jupyter notebook & pycharm (anaconda)
C. Virus(贪心)
【OpenCV】 人脸识别
网易云信音视频能力中台,聚焦银行业数字化转型
[QNX Hypervisor 2.2用户手册]10.7 vdev pci-dummy
干货,分布式数据库在金融核心场景的落地实践|腾讯云数据库
入门 Polkadot 平行链开发,看这一篇就够了
Unity图集优化原理
【C】函数和递归的使用
nuxt中使用字体图标,解决第一次可以加载出来,刷新页面图标消失的问题
SPFA模板