1. Redis单线程的本质
Redis
在处理客户端的读写请求时,只有一个主线程,而处理另外一些操作,
Redis
会fork
出其他的子线程来处理:
-
主从数据同步
-
切片集群数据同步
-
过期键值异步删除
-
AOF或RDB持久化
2. 单线程为什么那么快?
主要有以下四个原因
-
内存操作
-
高效的底层数据结构
-
多路复用IO模型
-
避免多线程切换开销
内存操作
Redis是内存数据库,CPU读取内存的速度要比读取磁盘的速度快得多。
高效的底层数据结构
Redis提供了五种非常好用的数据类型:String
,List
,Hash
,Set
,Sorted Set
。
Redis有六种底层数据结构,分别为哈希表,压缩列表,跳表,整数数组,简单动态字符串。
多路复用IO模型
多路复用IO模型是非阻塞的,其内置的红黑树可以高效地添加或查找FD,且只会将已经就绪的的FD从内核空间复制到用户空间,因此很多网络应用处理请求时都是使用多路复用IO模型。
避免多线程切换
Redis读取非常快,所以如果采用多线程的话,会产生以下两个问题:
-
多线程切换带来的额外开销:因为Redis读写非常快速,因为如果采用多线程,那么线程切换就非常频繁,所以如果采用多线程的话,Redis大部分时间可能都在切换线程。
-
数据加锁的性能损耗:多线程访问同一个数据的话,为了避免竞争,肯定需要加锁保证数据操作的原子性,而加锁与等待锁的释放,让多个线程在读取同一个数据需要排队等待,所以效率并不比单线程强多少。
Redis也是采用多线程的处理方式,不过,Redis在处理请求时只有一个主线程,但仍然做非常快速的响应,这是由于Redis的数据读写都在内存中,而内存的访问是非常快速的。