您的位置:首页 > 数据库 > Redis

Redis监控数据分布工具Redis-audit 使用总结

jiangu66 2013-07-13 20:02 29 查看
Redis-audit 是一个用ruby实现的脚本,通过它,我们可以知道每一类 key 对内存的使用量。它可以提供的数据有:某一类 key 值的访问频率如何,有多少值设置了过期时间,某一类 key 值使用内存的大小,这很方便让我们能排查哪些 key 不常用或者压根不用。

比较了下,比这些 Sentinel,Redis Live,Redis Faina,Redis-sampler,Redis-rdb-tools 监控或者数据分布工具要好!

下载

git clone https://github.com/snmaynard/redis-audit.git
下载后有如下几个文件,文件制定的ruby版本,redis版本可能会需要根据你已安装的进行调整:

Gemfile Gemfile.lock README.md redis-audit.rb

可能会涉及到安装一些依赖包

gem install bundle


使用

bundle exec ruby redis-audit.rb [host] [port] [dbnum] [(optional)sample_size]

比如:

bundle exec ruby redis-audit.rb 127.0.0.1 6379 1 10000

10000 是指随机个数,如果超过数据库的键的数量,则遍历所有键,如果小于,则随机10000 ,10000个可能重复

输出:



分析:

监控了一下脚本的执行,原理上都是发请求给redis,

1.先是尝试连接:"select" "1"

2.然后获取键的数量:"dbsize"

3.如果输入的Sample Size大于数据库键的数量,则遍历所有的键,不随机;

如果小于,则以我们输入的采样个数,进行随机样本次数,获取到随机键:"randomkey"

4.每个键都进行如下三步操作,比如键为horse:39:

4.1 "debug" "object" "horse:39" 这个是用来计算内存使用的,和键的闲置时间
4.2 "type" "horse:39" 这个是用来判断键值的类型的
4.3 "ttl" "horse:39" 这个是用来看这个键的有效期的

这样,再整合info的其他数据,slow log的,几个client连着,如此般的监控脚本我们自己也可以用其他语言去实现,比如时下流行的html5做个监控界面。
标签: