大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说Redis事件机制[亲测有效],希望您对编程的造诣更进一步.
Redis服务器是一个事件驱动程序,服务器需要处理以下两类事件:
- 文件事件:Redis通过套接字与客户端连接,文件事件是服务器对套接字操作的抽象。
- 时间事件:Redis服务器中的一些操作需要给定的时间点执行,时间事件时对这类定时操作的抽象。
文件事件
文件事件处理器使用I/O多路复用同时监听多个套接字。
文件事件处理器的构成
文件事件处理器的四个组成部分:套接字、I/O多路复用程序、文件事件分派器以及事件处理器。
文件事件是对套接字操作的抽象,每当一个套接字准备好执行连接应答(accept)、写入、读取、关闭等操作
时,就会产生一个文件事件。一个服务器会连接多个套接字,所以多个文件事件可能并发出现。
I/O多路复用程序负责监听多个套接字。尽管会并发,但是产生事件都放到一个队列里,以有序、同步、每次一个
套接字的方式向分派器传送套接字。
I/O多路服用程序的实现
通过包装select、epoll、evport和kqueue这些函数库来实现的。提供相同的API,可以互换。
文件事件的处理器
连接应答器
请求处理器
命令回复器
复制处理器
时间事件
未完待续
Reference
《Redis设计与实现》
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5813.html