redis多路复用IO模型 以及 6.0引入的多线程模型

redis为什么选择单线程

  1. 采用多线程的话,会出现上下文切换的开销
  2. 采用多线程,会带来共享资源的竞争控制,比如多个线程同时访问同一个资源(键值)时,需要额外的手段来保障共享资源的正确性,会带来额外的开销。多线程开发会引入同步语句来保护共享资源的并发访问,会降低代码的可调试性和可维护性。

为什么redis采用单线程还能如此的快

  1. 大部分操作在内存上完成
  2. 采用了高效的数据结构,如 跳表、哈希表。
  3. 采用了多路IO复用机制,使其在网络IO的操作下,能并发的处理大量客户端的请求,实现高吞吐量。

IO多路复用指的是,Redis采用linux的Epoll机制,实现内核中同时存在多个监听中的套接字和已监听的套接字,内核会一直监听这些套接字,一但有请求到达时,就会放到事件队列中,redis的主线程会不断从事件队列中取事件去消费。

redis 6.0版本引入的多线程

redis在6.0版本引入了多线程,其实不仅仅实在6.0,在6.0版本之前,redis也有其他线程在工作,比如rdb文件备份。6.0之后实在IO多路复用的流程中引入了多线程。

为什么引入多线程,因为读写网络的网络调用在redis执行期间占据了大量的时间。如果把网络读写交给线程组实现,会带来很大的方便,多线程只用在网络的读写和协议解析,执行redis命令的仍然是主线程,也不会带来资源竞争等问题。

相关推荐
微学AI15 分钟前
时序大模型 TimechoAI 赋能工业时序数据底层技术优势与实操
数据库·大模型·时序大模型
北顾笙98025 分钟前
MYSQL-day03
数据库·sql·mysql
MXsoft61826 分钟前
**混合云统一监控实践:私有云+公有云的一体化运维方案**
运维·网络·数据库
其实防守也摸鱼1 小时前
无线网络安全--10 规避WLAN验证之挫败MAC地址限制
网络·智能路由器·php·教程·虚拟机·wlan·无线网络安全
瀚高PG实验室1 小时前
java中间件无法连接数据库
java·数据库·中间件·瀚高数据库
ULIi096kr1 小时前
MySQL大表优化终极方案:单表数据量上限、卡顿解决、分表分库实战教程
数据库·mysql
霖霖总总1 小时前
[MongoDB小技巧07]MongoDB 深度解析:find中投影与排序的底层机制与性能调优实战
数据库·mongodb
TechWayfarer1 小时前
云服务器地域怎么选:用离线IP数据库识别用户来源并优化部署
服务器·数据库·python·tcp/ip·数据分析
deviant-ART1 小时前
MySQL里的三个concat函数
数据库·mysql
H_老邪1 小时前
1044 - Access denied for user ‘root‘@‘%‘ to database ‘nacos‘
数据库·mysql