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 
相关推荐
2401_878530219 小时前
机器学习与人工智能
jvm·数据库·python
tianyuanwo9 小时前
MySQL 深度解析:从核心概念到实战指南,及数据库选型决策
数据库·mysql·centos
代码探秘者9 小时前
【算法】吃透18种Java 算法快速读写模板
数据结构·数据库·python·算法·spring
深蓝轨迹9 小时前
Redis 消息队列
java·数据库·redis·缓存·面试·秒杀
曹牧10 小时前
Oracle:分批查询
数据库·oracle
祭曦念10 小时前
MySQL基础运维:mysqldump全量备份与恢复实操 | 新手可直接落地的备份指南
运维·数据库·mysql
于樱花森上飞舞10 小时前
【Redis】初识Redis
数据库·redis·缓存
羊小猪~~10 小时前
【QT】-- QMainWindow简介
开发语言·数据库·c++·后端·qt·前端框架·求职招聘
codkingo10 小时前
Skill:Agent 的可插拔能力单元
数据库·oracle
Boop_wu10 小时前
[MyBatis] MyBatis 快速入门(1)
数据库·oracle