Redis 实战之监视器

监视器

  • 成为监视器
  • 向监视器发送命令信息
  • 总结


成为监视器

发送MONITOR 命令可以让一个普通客户端变为一个监视器, 该命令的实现原理可以用以下伪代码来实现:

def MONITOR():# 打开客户端的监视器标志client.flags |= REDIS_MONITOR# 将客户端添加到服务器状态的 monitors 链表的末尾server.monitors.append(client)# 向客户端返回 OKsend_reply("OK")

举个例子, 如果客户端 c10086 向服务器发送 MONITOR 命令, 那么这个客户端的 REDIS_MONITOR 标志会被打开, 并且这个客户端本身会被添加到 monitors 链表的表尾。
假设客户端 c10086 发送 MONITOR 命令之前, monitors 链表的状态如图 24-2 所示, 那么在服务器执行客户端 c10086 发送的 MONITOR 命令之后, monitors 链表将被更新为图 24-3 所示的状态。
在这里插入图片描述
在这里插入图片描述

向监视器发送命令信息

服务器在每次处理命令请求之前, 都会调用 replicationFeedMonitors 函数, 由这个函数将被处理命令请求的相关信息发送给各个监视器。

以下是replicationFeedMonitors 函数的伪代码定义, 函数首先根据传入的参数创建信息, 然后将信息发送给所有监视器:

def replicationFeedMonitors(client, monitors, dbid, argv, argc):# 根据执行命令的客户端、当前数据库的号码、命令参数、命令参数个数等参数# 创建要发送给各个监视器的信息msg = create_message(client, dbid, argv, argc)# 遍历所有监视器for monitor in monitors:# 将信息发送给监视器send_message(monitor, msg)

举个例子, 假设服务器在时间 1378822257.329412 , 根据 IP 为 127.0.0.1 、端口号为 56604 的客户端发送的命令请求, 对 0 号数据库执行命令 KEYS * , 那么服务器将创建以下信息:

1378822257.329412 [0 127.0.0.1:56604] "KEYS" "*"

如果服务器 monitors 链表的当前状态如图 24-3 所示, 那么服务器会分别将信息发送给 c128 、 c256 、 c512 和 c10086 四个监视器, 如图 24-4 所示。
在这里插入图片描述

总结

客户端可以通过执行 MONITOR 命令, 将客户端转换成监视器, 接收并打印服务器处理的每个命令请求的相关信息。
当一个客户端从普通客户端变为监视器时, 该客户端的 REDIS_MONITOR 标识会被打开。
服务器将所有监视器都记录在 monitors 链表中。
每次处理命令请求时, 服务器都会遍历 monitors 链表, 将相关信息发送给监视器。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/10026.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解压.cpio.gz文件的步骤

cpio是一种用于创建和恢复文件系统映像的工具,而gz则是gzip压缩工具的扩展名。当你遇到一个名为.cpio.gz的文件时,这意味着这个文件已经被cpio和gzip联合压缩过。解压这样的文件需要两个步骤:首先解压缩,然后解cpio。 以下是解压.…

vtkvolume与vtkactor的区别与联系

参考: https://blog.csdn.net/qq_39966730/article/details/134926850 vtkVolume是vtkProp3D的子类,用于体渲染。类似于vtkActor(用于几何渲染),vtkVolume保存转换信息,如位置,方向和比例,以及指向映射器和…

C++初阶之stack,queue,priority_queue的使用和模拟以及仿函数的创建和使用

个人主页:点我进入主页 专栏分类:C语言初阶 C语言进阶 数据结构初阶 Linux C初阶 算法 欢迎大家点赞,评论,收藏。 一起努力,一起奔赴大厂 目录 一.stack,queue,priority_queue简介以及代码模拟 1.1 stack …

js设计模式--观察者模式

概述 观察者模式用于在对象之间建立 一对多 的依赖关系,当一个对象状态发生变化时,它的所有依赖者(观察者)都会收到通知并自动更新。在js中,观察者模式通常由两个角色组成:主体(Subject&#x…

uniapp 版本检查更新

总体来说uniapp的跨平台还是很不错的,虽然里面各种坑要去踩,但是踩坑也是开发人员的必修课和成长路。 这不,今天就来研究了一下版本检查更新就踩到坑了。。。先来看看检查更新及下载、安装的实现。 先来看看页面: 从左到右依次为…

推荐3个实用的github开源项目

目录: 1、AI生成高清短视频 2、媒体平台爬虫 3、文本转语音项目

【Linux网络编程】I/O多路转接之select

select 1.初识select2.了解select基本概念和接口介绍3.select服务器4.select特点及优缺点总结 点赞👍👍收藏🌟🌟关注💖💖 你的支持是对我最大的鼓励,我们一起努力吧!😃😃…

Spring Boot基础功能指引

文章目录 引言I 处理全局ExceptionII 定时任务III 引入springboot MVC3.1 添加Spring Web依赖3.2 重写SpringBootServletInitializer3.3 WebMvcConfigurer引言 I 处理全局Exception 类上加入注解@ControllerAdvice 定义controller切面方法上加入注解@ExceptionHandler(value =…

C++中的`this`指针详解

目录标题 1. this指针的基础1.1 this指针的定义1.2 this指针的用途 2. this指针的详细用法2.1 区分同名的成员和参数2.2 链式调用2.3 返回对象自身的地址 3. this在特殊情况下的用途3.1 在构造函数中使用this3.2 与智能指针结合使用 4. this指针的限制和注意事项4.1 静态成员函…

vue2 与vue3的差异汇总

Vue 2 与 Vue 3 之间存在多方面的差异,这些差异主要体现在性能、API设计、数据绑定、组件结构、以及生命周期等方面。以下是一些关键差异的汇总: 数据绑定与响应式系统 Vue 2 使用 Object.defineProperty 来实现数据的响应式,这意味着只有预…

系统架构设计师 - 计算机组成与体系结构(1)

计算机组成与体系结构 计算机组成与体系结构计算机结构 ★CPU 组成结构运算器组成控制器组成 计算机体系结构冯诺依曼结构哈弗结构 嵌入式芯片(了解) 存储系统 ★★★★概述Cache主存编址磁盘管理磁盘基本结构与存取过程磁盘优化分布存储磁盘管理 大家好…

数据挖掘(二)数据预处理

前言 基于国防科技大学 丁兆云老师的《数据挖掘》 数据挖掘 数据挖掘(一)数据类型与统计 2、数据预处理 2.1数据清理 缺失值处理: from sklearn.impute import SimpleImputer# 创建一个SimpleImputer对象,指定缺失值的处理策略…

Spring框架学习笔记(二):Spring IOC容器配置 Bean,分别基于XML配置bean 和 基于注解配置 bean

1 Spring 配置/管理 bean 介绍 Bean 管理包括两方面 :创建 bean 对象;给 bean 注入属性 Bean 配置方式:基于 xml 文件配置方式;基于注解方式 2 基于 XML 配置 bean 2.1 通过类型来获取 bean 方法:给getBean传入一…

从零开始学习MySQL 事务处理

事务处理与ACID特性 事务是数据库操作的基本单元,它确保一组操作要么全部成功,要么全部失败,以此来维护数据库的一致性。这四个字母缩写ACID代表了事务的四大特性: 原子性(Atomicity)**:事务被…

无人机+三角翼:小摩托无人机技术详解

无人机与三角翼的结合,为航空领域带来了一种新型且独特的飞行器——“小摩托”无人机。这种无人机结合了无人机的灵活性和三角翼的飞行稳定性,成为了航空运动领域中的一款热门产品。以下是对“小摩托”无人机技术的详解: 1. 定义与特点&#…

MFC中关于CMutex类的学习

MFC中关于CMutex类的学习 最近在项目中要实现两个线程之间的同步,MFC中提供了4个类,分别是CMutex(互斥量)、CCriticalSection(临界区)、CEvent(事件对象)、CSemaphore(信号量)。有关这4个类的说明,大家可以参考微软官方文档: CM…

七、Redis三种高级数据结构-HyperLogLog

Redis HyperLogLog是用来做基数统计的算法,HyperLogLog在优点是,在输入的元素的数量或者体积非常大时,计算基数占用的空间总是固定的、并且非常小。在Redis里每个HyperLogLog键只需花费12KB内存,就可以计算接近 264 个元素的基数。…

#04 构建您的第一个神经网络:PyTorch入门指南

文章目录 前言理论基础神经网络层的组成前向传播与反向传播 神经网络设计步骤1:准备数据集步骤2:构建模型步骤3:定义损失函数和优化器步骤4:训练模型步骤5:评估模型结论 前言 在过去的几天里,我们深入了解了…

头歌实践教学平台:CG1-v2.0-直线绘制

第1关&#xff1a;直线光栅化-DDA画线算法 一.任务描述 1.本关任务 (1)根据直线DDA算法补全line函数&#xff0c;其中直线斜率0<k<1&#xff1b; (2)当直线方程恰好经过P(x,y)和T(x,y1)的中点M时&#xff0c;统一选取直线上方的T点为显示的像素点。 2.输入 (1)直线两…

使用com.google.common.collect依赖包中的Lists.transform()方法转换集合对象之后,修改集合中的对象属性,发现不生效

目录 1.1、错误描述 &#xff08;1&#xff09;引入依赖 &#xff08;2&#xff09;模拟代码 &#xff08;3&#xff09;运行结果 1.2、解决方案 1.1、错误描述 最近在开发过程中&#xff0c;使用到了com.google.common.collect依赖包&#xff0c;通过这个依赖包中提供的…