redis批量删除key的步骤
由于误用插件,某台服务器上的redis实例存在数百万无用的key。为了删除无用数据,上网查找redis批量删除key的方法,发现使用过程中都有问题。经过本人的研究,终于找到redis批量删除key的正确用法。
本文分享最新版Redis批量删除key的方法,希望能帮到遇到同样问题的网友。
redis批量删除key
网上许多文章和教程给出的redis批量删除key命令是:
redis-cliKEYS"$PATTERN"|xargsredis-cliDEL
在本人的实践中,这条命令存在两个问题:
1.redis-cliKEYS"$PATTERN"的结果会出现编号,不是纯粹的key列表,如下所示:
[root@node1]#redis-clikeys"*" 1)":default:is_blog_installed" 2)":site-options:1-notoptions"
本人用的是Redis5版本,未测试低版本Redis是否也会添加1),2)这样的编号。可以想到,因为编号的存在,管道后DEL删除的是错误的key;
2.如果key存在空格,管道后面的DEL将无法正确删除。例如key是”1234566″,传送到管道后面删除,就变成了删除两个key,与预期不符合。
经过一番研究,redis批量删除key的正确命令是:
redis-cli--rawKEYS"$PATTERN"|xargs-I{}redis-cliDEL"{}"
重点有两个,分别解决上述命令存在的问题:
- 使用–raw参数,去掉结果编号;
- xargs使用占位符,删除key时将整个结果传过去,避免了空格问题。
改正后的命令在本人的情况下运行正常,就是删除两百多万个key有点慢,花了半个多小时。
redis批量移动key
如果你知道有用key的模式,并且有用key数量很小,可以通过redis批量移动key,然后flushdb的方法快速删除,效率比上文提到的批量删除大量无用key高很多。
操作方法如下:
- 批量移动key:redis-cli--rawKEYS"$PATTERN"|xargs-L1-I{}redis-cliMOVE{}1,其中命令最后的1是备份数据库的编号;
- 清空当前数据库:redis-cliflushdb;
- 还原key:redis-cli-n1--rawKEYS"$PATTERN"|xargs-L1-I{}redis-cliMOVE{}0。
注意清空当前数据库的命令是flushdb,不能用flushall。flushdb和flushall的区别是:flushdb只会清空当前数据库的数据,而flushall会清空当前redis实例的所有数据。
redis-cli参数
上述命令使用redis-cli工具完成,在编号为0的默认数据库上操作。对于需要密码、远程redis主机的情况,redis-cli有如下有用参数:
-n:操作的数据库;
-a:redis数据库密码
-h:redis主机ip,通过-h可以远程批量删除key
-p:redis端口
更多参数请参考帮助文档。
以上就是redis批量删除key的步骤的详细内容,更多关于redis批量删除key的资料请关注毛票票其它相关文章!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。