温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

redis里显示key大小的shell脚本

发布时间:2020-08-09 21:27:09 来源:ITPUB博客 阅读:319 作者:chenfeng 栏目:关系型数据库

redis里可以显示key大小的shell脚本,很方便的定位redis里有哪些大key。

脚本内容如下:

# cat redis-print-keysize.sh

#!/usr/bin/env bash


human_size() {

        awk -v sum="$1" ' BEGIN {hum[1024^3]="Gb"; hum[1024^2]="Mb"; hum[1024]="Kb"; for (x=1024^3; x>=1024; x/=1024) { if (sum>=x) { printf "%.2f %s\n",sum/x,hum[x]; break; } } if (sum<1024) print "1kb"; } '

}


#redis_cmd='redis-cli'


redis_cmd='redis-cli -n 10'



# get keys and sizes

for k in `$redis_cmd keys "*"`; do key_size_bytes=`$redis_cmd debug object $k | perl -wpe 's/^.+serializedlength:([\d]+).+$/$1/g'`; size_key_list="$size_key_list$key_size_bytes $k\n"; done


# sort the list

sorted_key_list=`echo -e "$size_key_list" | sort -n`


# print out the list with human readable sizes

echo -e "$sorted_key_list" | while read l; do

    if [[ -n "$l" ]]; then

        size=`echo $l | perl -wpe 's/^(\d+).+/$1/g'`; hsize=`human_size "$size"`; key=`echo $l | perl -wpe 's/^\d+(.+)/$1/g'`; printf "%-10s%s\n" "$hsize" "$key";

    fi

done



脚本说明:

扫描哪个db,修改脚本里对应redis_cmd的位置,加入 -n选项,例如:


# redis-cli info  keyspace | grep db10

db10:keys=6,expires=0,avg_ttl=0


显示db10的里的6个key的大小:

将redis_cmd='redis-cli'改为redis_cmd='redis-cli -n 10'

运行:

# ./redis_key_sizes.sh

1kb        prod_domain_error

1kb        prod_solr_error

200.86 Kb  test_buffer_error

241.55 Kb  prod_comment_error

19.20 Mb   prod_ref_15_error

70.55 Mb   prod_ref_151_error


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI