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命令的仍然是主线程,也不会带来资源竞争等问题。

相关推荐
sjsjsbbsbsn5 小时前
向量数据库
数据库
逸Y 仙X5 小时前
文章十六:ElasticSearch 使用enrich策略实现大宽表
java·大数据·数据库·elasticsearch·搜索引擎·全文检索
Sherry Wangs5 小时前
MySQL 与向量数据库的核心区别:从结构化数据到语义搜索
数据库·mysql
@小柯555m5 小时前
MySql(高级操作符--高级操作符练习(2))
数据库·sql·mysql
计算机安禾5 小时前
【Linux从入门到精通】第37篇:NFS网络文件系统——无状态的数据共享
linux·网络·php
凯尔萨厮6 小时前
Springboot2.x+JSP项目创建
java·数据库
Mr_linjw6 小时前
MySQL 中监控和优化慢 SQL & 索引小知识
数据库·sql·mysql
mftang6 小时前
BSS段、Data段、Text段的具体含义和数据特性
数据库·算法
码农阿豪6 小时前
Python 操作金仓数据库的完全指南(上篇):连接管理与高可用
开发语言·数据库·python
手握风云-6 小时前
Redis:不只是缓存那么简单(四)
redis·缓存