监视器
2023-4-14
| 2023-8-2
0  |  阅读时长 0 分钟
type
status
date
slug
summary
tags
category
icon
password
Property
 
通过执行MONITOR命令, 客户端可以将自己变为一个监视器, 实时地接收并打印出服务器当前处理的命令请求的相关信息:
每当一个客户端向服务器发送一条命令请求时, 服务器除了会处理这条命令请求之外, 还会将关于这条命令请求的信息发送给所有监视器:
notion image
发送MONITOR命令可以让一个普通客户端变为一个监视器, 该命令的实现原理的伪代码来:
如果客户端c10086向服务器发送MONITOR命令, 那么这个客户端的REDIS_MONITOR标志会被打开, 并且这个客户端本身会被添加到monitors链表的表尾。
假设客户端c10086发送MONITOR命令之前, monitors链表的状态:
notion image
那么在服务器执行客户端c10086发送的MONITOR命令之后, monitors链表将被更新为:
 
notion image
 
服务器在每次处理命令请求之前, 都会调用replicationFeedMonitors函数, 由这个函数将被处理命令请求的相关信息发送给各个监视器。
replicationFeedMonitors 函数的伪代码定义, 函数首先根据传入的参数创建信息, 然后将信息发送给所有监视器:
假设服务器在时间1378822257.329412, 根据 IP 为127.0.0.1 、端口号为56604的客户端发送的命令请求, 对0号数据库执行命令 KEYS * , 那么服务器将创建以下信息:
么服务器会分别将信息发送给 c128 、 c256 、 c512 和 c10086 四个监视器:
notion image
  • Redis
  • 慢查询日志分区技术
    目录