文件事件线程模型

  • redis线程模型
  • 事件驱动设计,采用reactor模式——每当一个Event输入到Service Handler之后,该Service Handler会主动的根据不同的Event类型将其分发给对应的Request Handler来处理。

套接字

  • 每个套接字准备好执行连接应答、写入、读取、关闭等操作时,都会产生一个文件事件。
  • 一个服务通常会连接多个套接字。
  • 文件事件:对套接字操作的抽象。
    • 套接字可读(客户端write,close)、新的可应答套接字(客户端connect),套接字产生AE_READABLE事件。
    • 套接字可写(客户端read),套接字产生AE_WRITABLE事件。
    • 同一个套接字优先处理AE_READABLE事件。

I/O多路复用程序

  • 监听多个套接字,并通过队列传递产生了事件的套接字给下游事件分派器。

文件事件分派器

  • 接收队列中的套接字,并根据事件类型调用相应的事件处理器。
  • 上一个套接字关联的事件处理器执行完毕,才继续处理下一个套接字。
  • redis单线程指的是事件分派器单线程,建立连接时多线程的。

事件处理器

  • 是一个个函数,处理对应事件。 常用的有:
    • 连接应答处理器:redis服务器初始化时,关联服务器监听套接字产生的AE_READABLE事件。事件在客户端connect时产生,创建套接字。
    • 命令请求处理器:客户端连接成功后,关联客户端套接字的AE_READABLE事件。该事件在客户端发送请求时产生。
    • 命令回复处理器:服务器有命令回复需要传送给客户端时,关联客户端套接字的AE_WRITABLE事件。事件在客户端尝试读取时产生。

时间事件模型

  • 分为定期事件和周期事件。
  • 文件事件和时间事件之间是合作关系,服务器轮流处理,不会抢占,所以时间事件实际处理事件通常比设定的晚一点。

高效的单线程

原因:

  • 纯内存操作。
  • 非阻塞I/O多路复用。
  • C语言,效率高。
  • 单线程没有线程切换开销。

相关文章: