Redis单线程模型详解

这里写目录标题

  • Redis 单线程模型简介
    • 文件事件
    • 常用的文件事件处理器
    • 客户端与Redis通信的一次流程
  • Redis为什么采用单线程模型
  • Redis 为什么要引入多线程呢?
  • 为什么Redis单线程模型也能效率这么高?

Redis 单线程模型简介

Redis 内部使用文件事件处理器 file event handler ,这个文件事件处理器是单线程的,所以 Redis 才叫做单线程的模型。它采用 IO 多路复用机制同时监听多个 socket,将产生事件的 socket 压入内存队列中,事件分派器根据 socket 上的事件类型来选择对应的事件处理器进行处理。

文件事件处理器的结构包含4个部分:①多个socket;②IO多路复用程序;③文件事件分派器;④事件处理器(命令请求处理器,命令回复处理器,连接应答处理器等等)。
Redis单线程模型详解_第1张图片

文件事件处理器的工作流程如下:

  1. 当被监听的套接字准备好执行连接应答(accept)、读取(read)、写入(write)、关闭(close)等操作时,与操作相对应的文件事件就会产生,这时文件事件处理器就会调用套接字之前关联好的事件处理器来处理这些事件。
  2. 文件事件处理器是单线程模式运行的,但是通过IO多路复用机制监听多个socket,并根据socket目前执行的任务来为套接字关联不同的事件处理器。可以实现高性能的网络通信模型。又可以跟内部其他单线程的模块进行对接,保证了Redis内部的线程模型的简单性。

文件事件

文件事件是对套接字操作的抽象, 每当一个套接字准备好执行连接应答(accept)、写入、读取、关闭等操作时&#

你可能感兴趣的:(Redis,redis,单线程模型)