架构师_程序员

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 414|回复: 0

[Redis] redis 通配符 批量删除key

[复制链接]
发表于 2019-8-12 17:12:14 | 显示全部楼层
zu
Redis 中 DEL指令支持多个key作为参数进行删除 但不支持通配符,无法通过通配符批量删除key,不过我们可以借助 Linux 的管道和 xargs 指令来完成这个动作

比如要删除所有以user开头的key 可以这样实现:

[root@dev_opayredis src]# redis-cli keys "user*"
1) "user1"
2) "user2"
[root@dev_opayredis src]# redis-cli keys "user*" | xargs redis-cli del
(integer) 2

删除成功
注意:命令只适用于Linux服务器,不适用于Windows服务器。

做redis缓存有bug导致脏数据太多就需要清理。但redis的del默认是不支持通配符批量删除的,我们使用linux命令实现批量删除

  1. redis-cli -h 192.168.0.2 -a pwd -n 12 keys keys_session_info2_* | xargs redis-cli -h 192.168.0.2 -a pwd -n 12  del
复制代码
  • -h redis主机地址
  • -a 密码
  • -n 指定数据库编号
  • keys 通配符key



删除指定通配符key的指定行数据

  1. #注意三行合并为一行
  2. redis-cli -h 192.168.0.2 -a ${pwd} -n 12 keys keys_session_info2_* |  
  3. awk 'NR>0 && NR<10000 {print}' |  
  4. xargs redis-cli -h 192.168.0.2 -a ${pwd} -n 12  del
复制代码






上一篇:购买汽车u盘3T内容
下一篇:在深圳失业的第75天
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|Archiver|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2020-3-29 00:51

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表