Redis IO模型
通俗的理解 Redis 是一个单进程单线程模型的 KV 内存数据库,截止到目前官方会在年底发布多线程版本,并且 Redis 也有自己的持久化方案。采用 I/O 复用模型和非阻塞 IO 技术,被广泛应用在高并发场景中。
Redis 高性能的几个关键点:
- 完全基于内存操作,数据也是存储在内存中。
- 数据结构简单,很多查找和操作的时间复杂度在 O(1)。
- 单线程模式,避免了上下文的切换和锁竞争。
- 使用了 I/O 多路复用模型和非阻塞 IO。
Redis 同时支持多个客户端连接,采用 I/O 多路复用模型(select\poll\epoll)可以同时监听多个 IO 流事件。
多路指的是多个网络连接,复用指的是复用同一个线程。
采用多路IO复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络IO的时间消耗),且Redis在内存中操作数据的速度非常快(内存内的操作不会成为这里的性能瓶颈),主要以上两点造就了Redis具有很高的吞吐量。
TODO I/O 多路复用