redis安全删key脚本

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis安全删key脚本相关的知识,希望对你有一定的参考价值。

需求:

删除指定前缀开头的rediskey ,扫描和删除过程中对线上无感知

 

只要知道线上操作的时候我们要用scan来代替 keys ,这一点就行了,简单脚本如下:

 

del.sh

 1 #!/bin/bash
 2 
 3 for((i = 1; i <= 50000; i++))
 4 do
 5     b=$[ $i * 100 ]
 6     echo $b
 7         redis-cli -h test.m.cnhza.kvstore.aliyuncs.com -a test:Paasword scan $b  match cache:info_*  count 100 |xargs -i redis-cli -h test.m.cnhza.kvstore.aliyuncs.com -a test:Paasword  del {}
 8         redis-cli -h test.m.cnhza.kvstore.aliyuncs.com -a test:Paasword scan $b  match cache:userb*  count 100 |xargs -i redis-cli -h test.m.cnhza.kvstore.aliyuncs.com -a test:Paasword  del {}
 9         redis-cli -h test.m.cnhza.kvstore.aliyuncs.com -a test:Paasword scan $b  match cache:userc*  count 100 |xargs -i redis-cli -h test.m.cnhza.kvstore.aliyuncs.com -a test:Paasword  del {}
10 done

 

执行:

sh del.sh >>echo.log &

 

watch wc -l echo.log

 

 

这样就可以了,因为常用,记录一下。

 

以上是关于redis安全删key脚本的主要内容,如果未能解决你的问题,请参考以下文章

正确的Redis分布式锁实现(Distributed lock)

基于 Redis 实现分布式锁,分析解决锁误删情况 及 利用Lua脚本解决原子性问题并改造锁

redis 怎样查找一个key?

linux脚本运行后把脚本删了会怎么办

Redis 如何高效安全删除大 Hash Key

Redis | 黑马点评 + 思维导图分布式锁