两种情况:

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

2.删除一个大的list,set,zset,hash,这种得分批次减少大小,一直缩到0再删

 

第一种情况:只要知道线上操作的时候我们要用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

 

 

如果是大的list,set则需要用rem trim 等缩小尺寸再删

 

相关文章:

  • 2022-12-23
  • 2021-05-03
  • 2022-12-23
  • 2022-02-23
  • 2022-12-23
  • 2021-08-30
  • 2022-12-23
  • 2021-07-08
猜你喜欢
  • 2022-01-11
  • 2021-07-20
  • 2021-09-20
  • 2021-12-13
  • 2022-12-23
  • 2021-11-22
相关资源
相似解决方案