《Reids 设计与实现》第二十章 监视器

文章目录

  • 《Reids 设计与实现》第二十章 监视器
  • 一、简介
  • 二、成为监视器
  • 三、向监视器发送命令信息
  • 四、重点回顾

一、简介

通过执行 MONITOR 命令,客户端可以将自己变为一个监视器,实时地接收并打印处服务器当前处理地命令请求的相关信息:

每当一个客户端向服务器发送一条命令请求时,服务器除了会处理这条命令请求之外,还会将关于这条命令请求的信息发送给所有监视器,如图 23-1 所示

二、成为监视器

发送 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*,那么服务器将创建以下信息:

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

四、重点回顾

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

《Reids 设计与实现》第二十章 监视器相关推荐

  1. 《Reids 设计与实现》第十章 客户端

    <Reids 设计与实现>第十章 客户端 文章目录 <Reids 设计与实现>第十章 客户端 一.简介 二.客户端属性 1.套接字描述符 2.名字 3.标志 4.输入缓冲区 5 ...

  2. 第二十章 使用系统监视器 - 定义系统监视器组件

    文章目录 第二十章 使用系统监视器 - 定义系统监视器组件 `Sensor Classes` Subscriber Classes `Notifier Classes` 健康监测 运行状况监视器概述 ...

  3. 《Reids 设计与实现》第二章 字典

    <Reids 设计与实现>第二章 字典 文章目录 <Reids 设计与实现>第二章 字典 一.字典 1.简介 2.字典的实现 3.哈希算法 4.解决键冲突 5.rehash 6 ...

  4. 《Reids 设计与实现》第十一章 服务器

    <Reids 设计与实现>第十一章 服务器 文章目录 <Reids 设计与实现>第十一章 服务器 一.简介 二.命令请求的执行过程 1.发送命令请求 2.读取命令请求 3.命令 ...

  5. activiti高亮显示图片_【正点原子FPGA连载】第二十章SD卡读BMP图片HDMI显示实验领航者 ZYNQ 之嵌入式开发指南...

    1)实验平台:正点原子领航者ZYNQ开发板 2)平台购买地址:https://item.taobao.com/item.htm?&id=606160108761 3)全套实验源码+手册+视频下 ...

  6. 修改dts后重编译_「正点原子FPGA连载」第二十章另一种方式编译ZYNQ镜像

    1)摘自[正点原子]领航者 ZYNQ 之linux驱动开发指南 2)实验平台:正点原子领航者ZYNQ开发板 3)平台购买地址:https://item.taobao.com/item.htm?& ...

  7. 《Reids 设计与实现》第十九章 慢查询日志

    <Reids 设计与实现>第十九章 慢查询日志 文章目录 <Reids 设计与实现>第十九章 慢查询日志 一.简介 二.慢查询记录的保存 三.慢查询日志的阅览和删除 四.添加新 ...

  8. 《Reids 设计与实现》第十八章 事务

    <Reids 设计与实现>第十八章 事务 文章目录 <Reids 设计与实现>第十八章 事务 一.简介 二.事务的实现 1.事务开始 2.命令入队 3.事务队列 4.执行事务 ...

  9. 《Reids 设计与实现》第十五章 集群(中)

    <Reids 设计与实现>第十五章 集群(中) 文章目录 <Reids 设计与实现>第十五章 集群(中) 四.在集群中执行命令 1.计算键属于哪个槽 2.判断槽是否由当前节点负 ...

最新文章

  1. C# Redis实战(六)
  2. 蓝桥杯 参考题目 黄金队列(水题)
  3. python字典items返回什么_Python 字典items返回列表,iteritems返回迭代器
  4. html 样式初始化,css样式初始化
  5. java math mod_java8 Math新增方法介绍
  6. MFC 文档 视图 框架窗口间的关系 和消息传送规律
  7. 紧急重要四象限软件用哪款便签软件?
  8. WANLSHOP B2B2C + 社区种草 —— 运营级插件
  9. iMX6ULL u-boot2021.04移植
  10. 解空间树搜索 及 最优解
  11. 中美计算机软件著作权登记差异与比较
  12. 深圳大学《计算机论题》作业:伦理分析的一般框架进行案例分析
  13. 电子邮件的地址格式是怎样的?请说明各部分的意思。
  14. openwrt 默认ip修改
  15. 阿里云实时数仓搭建与组件选型
  16. 【跨境电商平台规则与合规研讨会】在跨境驿站顺利召开
  17. Python3 迁移怨声载道
  18. 局域网arp攻击_MAC与IP不得不说的故事--深入ARP工作原理
  19. SEO不应该忽视的9个谷歌排名因素
  20. 吉时利万用表DMM7510,值得拥有的触摸屏数采万用表

热门文章

  1. git 小乌龟 配置_Git-Bash和TortoiseGit小乌龟客户端配置记录
  2. 如何查看服务器数据库修改密码,如何查看服务器数据库密码
  3. Linux服务器---xopps
  4. Mouse Detected Problem
  5. idea 中新建Servlet
  6. js 的数组怎么push一个对象. Js数组的操作push,pop,shift,unshift JavaScrip
  7. jquery 性能优化与实践
  8. Struts1 生成Action请求的几种方式分析
  9. OAuth 授权timestamp refused问题
  10. Linux内存之Cache