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多路复用