Redis设实 - 12 事件 上 文件事件

《Redis设计与实现 黄建宏 著》第11章
该书基于Redis2.9,即Redis3.0开发版编写

两类事件

文件事件(file event)
Redis服务器通过套接字与客户端(或其他Redis服务器)连接, 文件事件是服务器对套接字操作的抽象
服务器与客户端(或其他Redis服务器)通信产生文件事件,服务器通过监听并处理这些事件完成一系列网络通信操作
时间事件(time event)
Redis服务器中一些操作(如serverCron函数)需在给定时间点执行, 时间事件是服务器对这类定时操作的抽象

文件事件

Redis基于Reactor模式开发出网络事件处理器,该处理器称 文件事件处理器(file event handler)
·文件事件处理器使用I/O多路复用(multiplexing)程序同时监听多个套接字,并根据套接字执行的任务为套接字关联不同 事件处理器
·当被监听的套接字准备好执行连接应答(accept)、读取(read)、写入(write)、关闭(close)等操作时,会产生相应文件事件,这时文件事件处理器会调用之前关联好的事件处理器处理这些事件

文件事件处理器的4个组成部分


套接字
当一个套接字准备好执行连接应答、写入、读取、关闭等操作时,会产生一个文件事件
因一个服务器通常会连接多个套接字,故 多个文件事件可能会并发出现
I/O多路复用程序
通过包装select、epoll、evport和kqueue这些I/O多路复用函数库实现
负责监听多个套接字,并向文件事件分派器传送产生了事件的套接字
I/O多路复用程序将产生事件的套接字放到一个队列中,通过该队列,以 有序(sequentially)、 同步(synchronously)、 每次一个的方式向文件事件分派器传送套接字
上一个传送的套接字事件处理完毕后(关联的事件处理器执行完毕后),I/O多路复用程序才会向文件事件分派器传送下一个套接字
文件事件分派器
接收I/O多路复用程序传来的套接字,根据套接字产生的事件类型,调用相应事件处理器
事件处理器
处理器是一个函数,定义某个事件发生时,服务器应执行的动作

事件类型

I/O多路复用程序可监听多个套接字的 AE_READABLEAE_WRITABLE事件
·套接字变得可读(客户端对套接字执行write或close操作)或有新的可应答套接字(客户端对服务器监听套接字执行connect操作)出现时,套接字产生AE_READABLE事件
·套接字变得可写(客户端对套接字执行read操作)时,套接字产生AE_WRITABLE事件
注,Redis服务器优先处理同一个套接字的AE_READABLE事件,即,服务器先读套接字,后写套接字

事件处理器

·连接应答处理器
对连接服务器的各个客户端进行应答
Redis初始化时,将监听套接字的AE_READABLE事件与该处理器关联
客户端连接服务器时,产生AE_READABLE事件
·命令请求处理器
接收客户端传来的命令请求
客户端成功连接服务器后,Redis将该客户端套接字的AE_READABLE事件与该处理器关联
客户端向服务器发送命令请求时,产生AE_READABLE事件
客户端连接服务器过程中,该客户端套接字的AE_READABLE事件始终与该处理器关联
·命令回复处理器
向客户端返回命令执行结果
服务器有命令执行结果要传送给客户端时,将客户端套接字的AE_WRITABLE事件始终与该处理器关联
客户端准备好接收命令执行结果时,产生AE_WRITABLE事件
命令执行结果传送结束后,关联解除
·复制处理器
处理主服务器和从服务器复制操作

一次完整的客户端与服务器连接事件示例


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值