【Redis实战】批量模糊删除(适用生产环境)

   日期:2020-08-08     浏览:129    评论:0    
核心提示:目前在网上看到的大部分文章都是通过keys 进行模糊匹配并删除的下面介绍3种删除方法,建议使用linux去操作,可以结合xargs(点击查看介绍)命令进行操作参数说明:[ip]: ip地址, 参数名 -> -h[port]: 端口号, 参数名 -> -p[password]: 密码, 参数名 -> -a, 没有密码则不输入 -a [password][index]: 缓存所在的库, 参数名 -> -nredis-cli -h [ip] -p [port..

目前在网上看到的大部分文章都是通过keys 进行模糊匹配并删除的

下面介绍3种删除方法,建议使用linux去操作,可以结合 xargs(点击查看介绍) 命令进行操作

参数说明:

[ip]: ip地址, 参数名 -> -h
[port]: 端口号, 参数名 -> -p
[password]: 密码, 参数名 -> -a, 没有密码则不输入 -a [password]
[index]: 缓存所在的库, 参数名 -> -n

 

keys命令

它会扫整个库,导致Redis阻塞,影响正常使用, 不建议使用

redis-cli -h [ip] -p [port] -a [password] -n [index] keys "User:*" | xargs redis-cli -h [ip] -p [port] -a [password] -n [index] del

这是目前网上常用的方法,通过keys 命令返回匹配到的key,然后再使用 xargs整合所有的并删除

但是这个方法有个致命的问题,就是它是通过keys去扫描模糊匹配,keys命令会导致Redis阻塞问题,并且keys命令在生产环境是禁用的

scan命令

它是通过游标的方式扫描 (推荐)

redis-cli -h [ip] -p [port] -a [password] -n [index] --scan --pattern 'User:*' | xargs redis-cli  -h [ip] -p [port] -a [password] -n [index] del

但是这个删除又有个可以忽略不计的小问题,就是它其实是通过xargs整合所有匹配到的key然后再通过del命令去删除的

虽然del命令是O(1)的时间复杂度,但是在大量删除key的情况下还是会有很微乎其微的效率问题,所以才会说可以忽略不计的小问题

 

scan + unlink 命令

墙裂推荐

关于unlink(点击查看介绍) 的介绍, 它是通过使用另一个线程去回收内存,原理是先取消key与keyspace的连接,然后再异步删除键值对,这样就不会影响现有的Redis使用了

unlink命令在4.0.0版本之后可使用

redis-cli -h [ip] -p [port] -a [password] -n [index] --scan --pattern 'User:*' | xargs redis-cli  -h [ip] -p [port] -a [password] -n [index] unlink

 

如果帮到你,请点个赞吧 O(∩_∩)O~

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服