架构师_程序员

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 146|回复: 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天
帖子永久地址: 

架构师_程序员 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
2、本站所有主题由该帖子作者发表,该帖子作者与架构师_程序员享有帖子相关版权
3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和架构师_程序员的同意
4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
7、架构师_程序员管理员和版主有权不事先通知发贴者而删除本文

码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

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

Mail To:help@itsvse.com

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

GMT+8, 2019-9-19 10:04

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

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