Redis有一个monitor命令,某个client执行monitor命令后,就成为了一个监控器,服务器端执行的所有命令都会发送给监控器


monitor 是一个用来debug的命令,可以帮助我们了解服务器正在发生什么


例如我们打开monitor监控服务器20分钟,可以收集到期间服务器执行的所有命令,那么就可以分析出很多信息,例如:


(1)什么命令执行得次数多


(2)哪些key是热点


(3)通过对get类型命令的提取,统计出发送流量 


……


monitor命令使用


127.0.0.1:6379> monitor

OK


执行后返回“OK”,说明此客户端已经成为了监控器,然后就进入了等待状态


当服务器端执行了命令后,这里会自动显示出执行信息,如:


1454886442.140044 [0 127.0.0.1:63773] "keys" "*"

1454886454.538036 [0 127.0.0.1:63773] "get" "user13"

1454886475.392050 [0 127.0.0.1:63773] "get" "mylist_score"


各部分的含义:


1454886442.140044 是时间戳


[0 127.0.0.1:63773] 其中分别为:数据库编号、clent的IP和端口


"keys" "*" 为执行的命令


monitor的实现思路


客户端发送monitor命令后,会发生3个主要的动作


(1)客户端的监视器标识被设置为true


(2)服务器把此客户端添加到了monitors链表的末尾


(3)向客户端返回“OK”


Redis 监控器_java


某个client发送命令请求后,server在执行完此命令后,会把命令信息同时发送给monitor链表中个每个client


Redis 监控器_java_02