Redis文件事件模型

news/2025/2/16 6:38:15/

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 事件与命令回复处理器之间的关联

http://www.ppmy.cn/news/1182510.html

相关文章

不容错过的Spring框架解析,掌握开发中的关键技术

Spring 原理 它是一个全面的、企业应用开发一站式的解决方案,贯穿表现层、业务层、持久层。但是 Spring仍然可以和其他的框架无缝整合。 Spring 特点 轻量级 控制反转 面向切面 容器 框架集合 Spring特征 Spring 核心组件 Spring 常用模块 Spring 主要包 Spring …

如何使用透明贴图实现火焰效果

1、透明贴图的原理 透明贴图是一种纹理贴图,用于模拟物体部分或全部的透明效果。其原理基于透明度和混合技术。 在计算机图形中,如何显示透明的物体是一个具有挑战性的问题。这是因为透明物体不会像不透明物体那样完全遮挡后面的物体,而是允…

用go封装一下封禁功能

思路 封禁业务也是在一般项目中比较常见的业务。我们也将它封装在库中作为功能之一。 我们同样使用adapter作为底层的存储结构,将封禁标示作为k-v结构存储。 把id和服务名称service作为key,把封禁的级别level作为value,以此我们能实现一些比…

AR眼镜安卓主板,智能眼镜光机方案定制

AR智能眼镜是一项涉及广泛技术的创新产品,它需要考虑到光学、显示、功耗、散热、延迟、重量以及佩戴人体工学等多个方面的因素,每一个项目都是技术进步所需攻克的难题。 在本文中,我们将重点讨论AR眼镜的主板和光学方案。 首先是AR智能眼镜的…

Cannot connect to the Docker

执行docker基础命令失败! Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running? 原因:docker服务没有启动。 解决方法:执行 systemctl start docker 即可。

GPT的广泛应用会对互联网公司造成挑战吗?——探讨GPT在实际使用中的应用和影响

文章目录 前言GPT 技术的背景和发展历程GPT 技术对互联网行业的影响GPT 技术在互联网行业中的应用GPT 技术对于用户隐私和数据安全的威胁GPT 技术对于人类工作岗位的影响加强 AI 伦理和监管加强 AI 安全性和隐私保护推动 AI 创新和发展,避免过度依赖 AIGPT 技术是一…

Leetcode刷题详解——不同路径

1. 题目链接:62. 不同路径 2. 题目描述: 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish”…

Python基于微博的舆情分析、热搜可视化系统

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝30W、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 1. 简介 基于Python Django的微博热搜、微博舆论可视化系统。通过微博舆情分析系统获取到最新微博舆情分析…