Redis 实战之监视器


成为监视器

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

def MONITOR():

    # 打开客户端的监视器标志
    client.flags |= REDIS_MONITOR

    # 将客户端添加到服务器状态的 monitors 链表的末尾
    server.monitors.append(client)

    # 向客户端返回 OK
    send_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 链表, 将相关信息发送给监视器。

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-09 11:08:09       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-09 11:08:09       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-09 11:08:09       82 阅读
  4. Python语言-面向对象

    2024-05-09 11:08:09       91 阅读

热门阅读

  1. 一分钟get如何在NIBSC官网查询标准品明细

    2024-05-09 11:08:09       36 阅读
  2. C#读sqlite数据库

    2024-05-09 11:08:09       35 阅读
  3. (二)JVM实战——jvm实战之运行时数据区详解

    2024-05-09 11:08:09       38 阅读
  4. vue3项目 文件组成

    2024-05-09 11:08:09       34 阅读
  5. 为什么C++11还要复杂的提出右值引用?

    2024-05-09 11:08:09       31 阅读
  6. C语言内存泄漏查找

    2024-05-09 11:08:09       34 阅读
  7. CentOS常见命令深度解析:从基础到进阶

    2024-05-09 11:08:09       31 阅读