redis为什么这么快

1.基于内存的实现

Redis 将数据存储在内存中,读写操作不会受到磁盘的 IO 速度限制,所以Redis的读写速度会非常的快。

2.高效的数据结构

Redis内置了多种高效的数据结构,如字符串、哈希表、列表、集合和有序集合等。这些数据结构都经过优化,能够在时间复杂度为O(1)的情况下完成大部分操作。

3.单线程模型

Redis采用单线程(Redis的网络IO和键值对读写是由一个线程来完成的)模型。这意味着它不会因为线程创建导致的性能消耗;不需要在不同线程之间进行上下文切换;避免了线程之间的竞争问题,比如添加锁、释放锁、死锁等。

4.I/O多路复用

I/O:网络I/O
多路:多个网络(客户端)请求
复用:使用一个线程
I/O多路复用官方解释:
所谓的I/O多路复用是一种同步的I/O模型,实现一个线程监听多个文件句柄,一旦某个文件句柄就绪就能够通知导对应应用程序进行相应的读写操作,没有文件句柄就绪时就会阻塞应用程序,从而释放cpu资源。
I/O多路复用山寨版解释:
所谓的I/O多路复用,通俗点讲就是:一个线程同时处理多个客户端的请求。
举个例子
一个考场有50个考生(客户端),只有一个监考老师(线程),当考生完成答卷时,举手示意老师,卷子写完了(发出请求),让老师过来收卷子,老师收好卷子放到讲台上,告知学生可以离开了(做相应的读写操作)。
一个老师能同时监考50个考生 = 一个线程能同时处理多个客户端的请求 = I/O多路复用
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值