文章目录
- [💖 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 后台线程
- 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