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 
相关推荐
Ai 编码助手5 小时前
MySQL中distinct与group by之间的性能进行比较
数据库·mysql
陈燚_重生之又为程序员5 小时前
基于梧桐数据库的实时数据分析解决方案
数据库·数据挖掘·数据分析
caridle5 小时前
教程:使用 InterBase Express 访问数据库(五):TIBTransaction
java·数据库·express
白云如幻5 小时前
MySQL排序查询
数据库·mysql
萧鼎5 小时前
Python并发编程库:Asyncio的异步编程实战
开发语言·数据库·python·异步
^velpro^6 小时前
数据库连接池的创建
java·开发语言·数据库
荒川之神6 小时前
ORACLE _11G_R2_ASM 常用命令
数据库·oracle
IT培训中心-竺老师6 小时前
Oracle 23AI创建示例库
数据库·oracle
小白学大数据6 小时前
JavaScript重定向对网络爬虫的影响及处理
开发语言·javascript·数据库·爬虫
time never ceases6 小时前
使用docker方式进行Oracle数据库的物理迁移(helowin/oracle_11g)
数据库·docker·oracle