• Redis文件事件模型


    Redis是事件驱动的程序,并基于Reactor模式开发了自己的网络事件处理器,被称之为文件处理器(File Event Handler)。
    文件处理器通过I/O多路复用程序来同时监听多个Socket,并根据Socket目前执行的任务来关联不同的事件处理器。当被监听的Socket准好执行应答(accept)、读取(read)、写入(write)和关闭(close)操作时,与操作相对应的文件事件就会产生,这时文件事件处理器就会调用Socket关联的事件处理器进行事件处理。

    文件处理器构成

    文件处理器主要包括Socket、I/O多路复用程序、文件派发器和事件处理器。
    文件处理器构成
    因为I/O多路复用同时监听多个Socket,那么一定存在多个事件并发的情况。Redis通过消息队列来解决并发的问题。通过消息队列可以有序、同步的将每个socket事件分配给文件事件派发器。
    文件处理器主要包括命令应答处理器、命令请求应答器和命令回复应答器

    • 命令应答处理器:为了对连接服务器的各个客户端进行应答, 服务器要为监听套接字关联连接应答处理器
    • 命令请求处理器:为了接收客户端传来的命令请求,服务器要为客户端套接字关联命令请求处理器
    • 命令回复处理器:为了向客户端返回命令的执行结果,服务器要为客户端套接字关联命令回复处理器

    C/S交互过程

    客户端/服务商交互流程
    以一个完整的C/S通讯示例进行分析

    1. Redis服务器启动,在main函数中,通过aeMain创建文件处理器
    2. 服务器的监听Socket的AE_READABLE事件处于监听状态下,而该事件所对应的处理器为连接应答处理器
    3. 客户端发起连接请求,监听Socket产生AE_READABLE事件,触发连接应答处理器执行;
    4. 连接应答处理器对客户端连接进行应答,创建客户端Socket,将客户端Socket的AE_READABLE事件与命令请求处理器关联
    5. 客服端向服务端发送一个命令请求,客户端产生AE_READABLE事件,触发命令请求处理器执行
    6. 执行命令将产生相应命令回复,服务器将客户端Socket的 AE_WRITABLE 事件与命令回复处理器进行关联
    7. 客户端尝试读取命令回复时,客户端Socket将产生 AE_WRITABLE 事件,触发命令回复处理器
    8. 命令回复处理器命令回复全部写入到Socket后,服务器就会解除客户端Socket套接字的 AE_WRITABLE 事件与命令回复处理器之间的关联
  • 相关阅读:
    Action模型 -- 增强型UML建模和后台代码的自动生成工具
    R包:TreeAndLeaf二分类树构建R包
    国产+开源:可视化流程引擎助力企业建立流程管理体系
    MyBatisPlus学习(4)—— 设置实体类
    网络安全竞赛C模块批量拿值脚本
    MySQL 三大日志(bin log、redo log、undo log)
    thinkphp在apache、nginx和iis下的URL重写
    “Invalid project description“问题解决
    中国智能交通系统行业市场全景调研与发展前景预测报告
    以可视化方式解释 Go 并发 - 通道
  • 原文地址:https://blog.csdn.net/kgcourage/article/details/134059073