Redis为什么是单线程,查询速度还这么快

1. Redis单线程的本质

Redis在处理客户端的读写请求时,只有一个主线程,而处理另外一些操作,

Redisfork出其他的子线程来处理:

  • 主从数据同步

  • 切片集群数据同步

  • 过期键值异步删除

  • AOF或RDB持久化

2. 单线程为什么那么快?

主要有以下四个原因

  • 内存操作

  • 高效的底层数据结构

  • 多路复用IO模型

  • 避免多线程切换开销

内存操作

Redis是内存数据库,CPU读取内存的速度要比读取磁盘的速度快得多。

高效的底层数据结构

Redis提供了五种非常好用的数据类型:StringListHashSetSorted Set

Redis有六种底层数据结构,分别为哈希表,压缩列表,跳表,整数数组,简单动态字符串。

多路复用IO模型

多路复用IO模型是非阻塞的,其内置的红黑树可以高效地添加或查找FD,且只会将已经就绪的的FD从内核空间复制到用户空间,因此很多网络应用处理请求时都是使用多路复用IO模型。

避免多线程切换

Redis读取非常快,所以如果采用多线程的话,会产生以下两个问题:

  • 多线程切换带来的额外开销:因为Redis读写非常快速,因为如果采用多线程,那么线程切换就非常频繁,所以如果采用多线程的话,Redis大部分时间可能都在切换线程。

  • 数据加锁的性能损耗:多线程访问同一个数据的话,为了避免竞争,肯定需要加锁保证数据操作的原子性,而加锁与等待锁的释放,让多个线程在读取同一个数据需要排队等待,所以效率并不比单线程强多少。

Redis也是采用多线程的处理方式,不过,Redis在处理请求时只有一个主线程,但仍然做非常快速的响应,这是由于Redis的数据读写都在内存中,而内存的访问是非常快速的。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值