Redis中统计各种数据大小的方法
如果MySQL数据库比较大的话,我们很容易就能查出是哪些表占用的空间;不过如果Redis内存比较大的话,我们就不太容易查出是哪些(种)键占用的空间了。
有一些工具能够提供必要的帮助,比如redis-rdb-tools可以直接分析RDB文件来生成报告,可惜它不能百分百实现我的需求,而我也不想在它的基础上二次开发。实际上开发一个专用工具非常简单,利用SCAN和DEBUG等命令,没多少行代码就能实现:
<?php
$patterns=array( 'foo:.+', 'bar:.+', '.+', );
$redis=newRedis(); $redis->setOption(Redis::OPT_SCAN,Redis::SCAN_RETRY);
$result=array_fill_keys($patterns,0);
while($keys=$redis->scan($it,$match='*',$count=1000)){ foreach($keysas$key){ foreach($patternsas$pattern){ if(preg_match("/^{$pattern}$/",$key)){ if($v=$redis->debug($key)){ $result[$pattern]+=$v['serializedlength']; }
break; } } } }
var_dump($result);
?>
热门推荐
10 导师寄语简短祝福语大全
11 门市开业口头祝福语简短
12 女儿婚礼女婿祝福语简短
13 恭喜祝福语回复语句简短
14 同学表白的祝福语简短
15 酒店疫情祝福语大全简短
16 送花顾客祝福语简短的话
17 婚礼早晨亲戚祝福语简短
18 婚礼父母在家祝福语简短