Redis线程模型
Redis内部使用的文件事件处理器(基于Reactor模式开发的)file event handler是单线程的,所以Redis线程模型才叫单线程模型,它采用IO多路复用机制同时监听多个socket,当被监听的socket准备好执行accep、read、write、close等操作时,IO多路复用程序会将这些事件的socket压入一个队列中,然后有序地的将这些socket传送给文件事件分派器,文件事件分派器接收到socket之后会根据socket产生的事件类型调用对应的事件处理器进行处理。
什么是IO多路复用机制?
IO多路复用技术是一种处理并发IO操作的技术,核心是让单个线程去监视多个连接,一旦某个连接触发了读、写事件,就去通知应用程序,去处理这个链接,传统的IO模型中,会为每一个连接开启一个线程处理其IO事件,这种模型系统开销大,资源消耗高,IO多路复用通常是通过调用系统的 select poll epoll 来监视IO事件。
IO多路复用技术的优点?
- 减少了线程的创建和开销,减少了系统的资源消耗。
- 提高了系统的并发能力,同等资源下可以处理更多的IO事件。
- 通过事件驱动的方式,避免了轮询方式的消耗。
文件事件处理器的组成部分?
- 多个socket。
- IO多路复用程序。
- 队列。
- 文件事件分配器。
- 文件事件处理器。
文件事件处理器有哪些具体的处理器?
- 连接应答处理器:用于处理客户端的连接请求。
- 命令请求处理器:用于执行客户端传过来的命令。
- 使用(使用次数最少)淘汰算法,LFU是淘汰一段时间内,使用次数最少的key。
Reidis 是单线程的为什么效率还这么高?
- Redis是基于内存操作的,数据存储在内存中,纯内存访问,而内存访问的速大概是100纳秒。
- 非阻塞的IO模型,Redis使用epol来实现IO多路复用技术,再加上Redis自身的事件处理模型,不在IO上浪费时间。
- 单线程避免了线程竞争切换带来的时间消耗。
- 高效的数据结构,合理的数据编码。
- 合理的线程模型,基于非阻塞的IO多路复用技术。
那为什么Redis 6.0之后又改用多线程呢?
随着网络硬件的发展,Redis开发者发现Redis的性能问题有时候会出现在网络IO处理上,单个线程处理网络请求的速度跟不上底层硬件的速度,于是在Redis 6.0中提出了多线程模型,可以采用多个IO线程来处理网络请求,提高处理网络请求的速度,Redis的多线程模型并不是抛弃了单线程,Redis还是使用单线程处理客户端请求,执行读写命令。
Redis多线程模式是默认关闭的。
如有不正确的地方请各位指出纠正。