Redis为什么这么快
Redis快的原因主要分为两大方面:
1.数据结构和内部编码
众所周知Redis的数据结构有string、hash、list、set、zset等等数据结构,这些数据结构也有不同的内部编码,而且根据存储的键值对的个数和大小来决定内部编码。
这样设计有两个好处:第一,可以改进内部编码,而对外的数据结构和命令没有影响;第二,多编码实现可以在不同场景下发挥各自的优势,性能也有所提升。
2.单线程架构
通常来讲,单线程处理能力要比多线程差,Redis却可以达到每秒万级别的处理能力。主要归结为三点:
第一,纯内存访问,Redis将所有数据放在内存中,内存的响应时长大约为100纳秒,这是Redis达到每秒万级别访问的重要基础。
第二,非阻塞I/O,Redis使用epoll作为I/O多路复用的实现,再加上Redis自身的事件处理模型将epoll中的连接、读写、关闭都转换为事件,不在网络I/O上浪费过多的时间。
第三,单线程避免了线程切换和竞态产生的消耗。