1、为什么Redis是单线程的呢?
这里强调的单线程是指网络请求模块使用一个线程来处理,即一个线程处理所有网络请求,其他模块仍用多个线程。
那为什么使用单线程呢?官方答案是:因为CPU不是Redis的瓶颈,Redis的瓶颈最有可能是机器内存或者网络带宽。既然单线程容易实现且CPU不会成为瓶颈,顺理成章地采用单线程的方案了。
Redis是基于Reactor模式开发自己的网络事件处理器:这个处理器被称为文件事件处理器(file event handler)。而这个文件事件处理器是单线程的,所以才叫redis的单线程模型,这也决定了redis是单线程的。
2、Redis单线程模型组成?
3、客户端与Redis一次完整通信过程
3.1、建立连接
3.2、执行set操作
4、Redis6.0 的多线程
4.1、Redis6.0 之前为什么一直不使用多线程?
Redis使用单线程的可维护性高。多线程模型虽然在某些方面表现优异,但是它却引入了程序执行顺序的不确定性,带来了并发读写的一系列问题,增加了系统复杂度、同时可能存在线程切换、甚至加解锁、死锁造成的性能损耗
4.2、Redis6.0 为什么要引入多线程呢?
因为Redis的瓶颈不在内存,而是在网络IO模块带来CPU的耗时,所以Redis6.0的多线程用来处理网络IO这部分,充分带来CPU资源,减少网络IO阻塞带来的性能损耗
4.3、Redis6.0如何开启多线程
默认是关闭多线程的,可以在conf文件进行配置开启:
io-threads-do-reads yes
io-threads 线程数
## 官方建议的线程数设置:4核的机器建议设置为2或3个线程,8核的建议设置为6个线程,线程数一定要小于机器核数,尽量不超过8个。
4.4、多线程模式下,是否存在并发安全问题?
在redis的多线程模式下,获取、解析命令,以及输出结果两个过程,可以配置成多线程执行,因为它毕竟是定位到的主要耗时点,但是命令的执行,也就是内存操作,依然是单线程运行的。所以,Redis的多线程部分只是用来处理网络数据的读写和协议解析,执行命令仍然是单线程顺序执行,也就不存在并发安全问题。
参考:《石杉的架构笔记》
可以关注以下公众号,掌握一手资料
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。