Redis线程模型

文章目录

  • [💖 Redis 单线程模型](#💖 Redis 单线程模型)
    • [⭐ 单线程监听大量的客户端连接](#⭐ 单线程监听大量的客户端连接)
    • [⭐ Redis 6.0 之前为什么不用多线程?](#⭐ Redis 6.0 之前为什么不用多线程?)
  • [💖 Redis多线程](#💖 Redis多线程)
    • [⭐ Redis 后台线程](#⭐ Redis 后台线程)
    • [⭐ Redis 网络IO多线程](#⭐ Redis 网络IO多线程)

对于读写命令来说,Redis 一直是单线程模型。不过,在 Redis 4.0 版本之后引入了多线程来执行一些大键值对的异步删除操作 , Redis 6.0 版本之后引入了多线程来处理网络请求(提高网络 IO 读写性能)
👨‍🏫 Redis 线程模型(重要)

💖 Redis 单线程模型

⭐ 单线程监听大量的客户端连接


⭐ Redis 6.0 之前为什么不用多线程?

  • 单线程编程容易并且更容易维护
  • Redis 的性能瓶颈不在 CPU,主要在内存和网络
  • 多线程就会存在死锁、线程上下文切换等问题,甚至会影响性能

Redis 6.0 版本之前的单线模式如下图:

💖 Redis多线程

⭐ Redis 后台线程

👨‍🏫 小林Coding Redis 线程模型

  • close_file:表示关闭相应文件描述符对应的文件(释放套接字、数据空间等)
  • aof_fsync:表示 AOF 刷盘
  • lazy_free:表示惰性释放空间


⭐ Redis 网络IO多线程

java 复制代码
//读请求也使用io多线程
io-threads-do-reads yes 

同时, Redis.conf 配置文件中提供了 IO 多线程个数的配置

java 复制代码
// io-threads N,表示启用 N-1 个 I/O 多线程(主线程也算一个 I/O 线程)
io-threads 4 
相关推荐
Greyson12 小时前
Layui表格如何使用第三方插件实现树形展示.txt
jvm·数据库·python
2401_871696522 小时前
mysql行级锁失效的原因排查_检查查询条件与执行计划
jvm·数据库·python
Elastic 中国社区官方博客3 小时前
Elasticsearch:快速近似 ES|QL - 第一部分
大数据·运维·数据库·elasticsearch·搜索引擎·全文检索
Dontla3 小时前
高基数(High Cardinality)问题介绍(Prometheus、高基数字段、低基数字段)
前端·数据库·prometheus
a9511416423 小时前
CSS如何实现元素隐藏不占位_使用display-none完全移除
jvm·数据库·python
SelectDB技术团队4 小时前
SelectDB Enterprise 4.0.5:强化安全与治理,构建企业级实时分析与 AI 数据底座
数据库·人工智能·apache doris
一 乐4 小时前
医院挂号|基于springboot + vue医院挂号管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·医院挂号管理系统
M--Y4 小时前
Redis的主从复制和哨兵
redis·主从复制·哨兵
ego.iblacat4 小时前
Redis 核心概念与部署
数据库·redis·缓存
m0_493934534 小时前
如何监控AWR数据收集Job_DBA_SCHEDULER_JOBS中的BSLN_MAINTAIN_STATS
jvm·数据库·python