(Redis设计与实现-5) 事件

redis使用单线程架构和I/O多路复用模型来实现高性能的内存数据库服务。一条命令从客户端到服务端不会马上被执行,全部命令都会进入一个队列中,而后逐个被执行。

一.文件事件redis

Redis服务器经过套接字与客户端进行链接,文件事件就是服务器对套接字操做的抽象。文件事件处理器使用I/O多路复用程序来同时监听多个套接字,并根据套接字目前执行的任务来为套接字关联不一样的事务处理器。当被监听的套接字准备好执行链接应答、读取、写入、关闭等操做时,与操做相对应的文件事件就会产生,这时文件事件处理器就会调用套接字以前关联好的事件处理器来处理这些事件。

图片描述

文件事件处理器 由四个部分组成:套接字、I/O多路复用程序、文件事件分派器以及事件处理器
I/O多路复用程序老是会将全部产生事件的套接字放到一个队列里面,而后经过这个队列以有序、同步、每次一个套接
字的方式向文件事件分派器传送套接字。当上一个套接字产生的事件被处理完毕以后,I/O多路复用程序才会继续向文
件事件分派器传送下一个套接字。


二.时间事件数据库

服务器对定时操做的抽象。事件分为:定时事件(指定时间执行一次);周期性事件(每隔一段时间执行一次)。目前Redis只使用周期性事件,而没有使用定时事件。
服务器将全部时间事件都放在一个无序链表中,每当时间事件执行器运行时,遍历整个链表,查找全部已到达的时间事
件,并调用相应的事件处理器
相关文章
相关标签/搜索