由于误用插件,某台服务器上的redis实例存在数百万无用的key。为了删除无用数据,上网查找redis批量删除key的方法,发现使用过程中都有问题。经过本人的研究,终于找到redis批量删除key的正确用法。
本文分享最新版Redis批量删除key的方法,希望能帮到遇到同样问题的网友。
redis批量删除key
网上许多文章和教程给出的redis批量删除key命令是:
redis-cli KEYS "$PATTERN" | xargs redis-cli DEL
在本人的实践中,这条命令存在两个问题:
1.redis-cli KEYS "$PATTERN"的结果会出现编号,不是纯粹的key列表,如下所示:
[root@node1]# redis-cli keys "*" 1) ":default:is_blog_installed" 2) ":site-options:1-notoptions"
本人用的是Redis 5版本,未测试低版本Redis是否也会添加1),2)这样的编号。可以想到,因为编号的存在,管道后DEL删除的是错误的key;
2.如果key存在空格,管道后面的DEL将无法正确删除。例如key是”123 4566″,传送到管道后面删除,就变成了删除两个key,与预期不符合。
经过一番研究,redis批量删除key的正确命令是:
redis-cli --raw KEYS "$PATTERN" | xargs -I {} redis-cli DEL "{}"
重点有两个,分别解决上述命令存在的问题:
- 使用 –raw 参数,去掉结果编号;
- xargs使用占位符,删除key时将整个结果传过去,避免了空格问题。
改正后的命令在本人的情况下运行正常,就是删除两百多万个key有点慢,花了半个多小时。
redis批量移动key
如果你知道有用key的模式,并且有用key数量很小,可以通过redis批量移动key,然后flushdb的方法快速删除,效率比上文提到的批量删除大量无用key高很多。
操作方法如下:
- 批量移动key:
redis-cli --raw KEYS "$PATTERN" | xargs -L1 -I{} redis-cli MOVE {} 1
,其中命令最后的1是备份数据库的编号; - 清空当前数据库:
redis-cli flushdb
; - 还原key:
redis-cli -n 1 --raw KEYS "$PATTERN" | xargs -L1 -I{} redis-cli MOVE {} 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的资料请关注其它相关文章!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]