优雅删除Redis中以xx开头的key

1、暴力删除

使用keys * 扫描所有的key,然后批量删除。key较多时,会阻塞redis,生产环境中需要慎重,适合并发小,keys数量少的场景。

关键命令:

docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  keys "a*" |xargs redis-cli -h 172.17.0.17 -p 6379 -n 0 del"

[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a1 1"
OK
[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a2 2"
OK
[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a3 3"
OK
[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  keys "a*""
1) "a1"
2) "a2"
3) "a3"
[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  keys "a*" |xargs redis-cli -h 172.17.0.17 -p 6379 -n 0 del"
(integer) 3
[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  keys "a*""
(empty array)

###如果需要密码,可以加上-a参数

2、优雅删除

关键命令:

docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0 --scan --pattern "a*" |xargs -n 1000 -r redis-cli -h 172.17.0.17 -p 6379 -n 0 del"

[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a1 1"
OK
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a2 2"
OK
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a3 3"
OK
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  --scan --pattern "a*""
a2
a1
a3
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0 --scan --pattern "a*" |xargs -N 1000 redis-cli -h 172.17.0.17 -p 6379 -n 0 del"
xargs: unrecognized option: N
BusyBox v1.31.1 () multi-call binary.

Usage: xargs [OPTIONS] [PROG ARGS]

Run PROG on every item given by stdin

        -0      Input is separated by NULs
        -a FILE Read from FILE instead of stdin
        -r      Don't run command if input is empty
        -t      Print the command on stderr before execution
        -p      Ask user whether to run each command
        -E STR,-e[STR]  STR stops input processing
        -I STR  Replace STR within PROG ARGS with input line
        -n N    Pass no more than N args to PROG
        -s N    Pass command line of no more than N bytes
        -P N    Run up to N PROGs in parallel
        -x      Exit if size is exceeded
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0 --scan --pattern "a*" |xargs -n 1000 -r redis-cli -h 172.17.0.17 -p 6379 -n 0 del"
(integer) 3
[root@VM-0-17-centos ~]# 
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  --scan --pattern "a*""
[root@VM-0-17-centos ~]# 
###如果需要密码,可以加上-a参数

备注:

xargs -n 参数的作用,表示每次执行的参数数量


### 注意-n参数,可以每次删除适量的

[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a1 3"
OK
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a2 3"
OK
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0  set a3 3"
OK
[root@VM-0-17-centos ~]# docker run --rm --name redis-cli -it goodsmileduck/redis-cli sh -c "redis-cli -h 172.17.0.17 -p 6379 -n 0 --scan --pattern "a*" |xargs -n 1 -r redis-cli -h 172.17.0.17 -p 6379 -n 0 del"
(integer) 1
(integer) 1
(integer) 1

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Java中删除Redis中以特定key开头的数据,可以使用Jedis库来完成操作。 首先,我们需要导入所需的Jedis库: ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.ScanParams; import redis.clients.jedis.ScanResult; ``` 然后,创建一个Jedis对象,并连接到Redis服务器: ```java Jedis jedis = new Jedis("localhost"); ``` 接下来,我们可以使用SCAN命令以迭代的方式遍历所有以特定key开头的数据,并逐个删除它们。可以使用ScanParams类来指定要匹配的key的pattern。例如,如果要删除以"mykey"开头的数据,可以这样做: ```java ScanParams scanParams = new ScanParams().match("mykey*"); String cursor = "0"; do { ScanResult<String> scanResult = jedis.scan(cursor, scanParams); for (String key : scanResult.getResult()) { jedis.del(key); } cursor = scanResult.getCursor(); } while (!cursor.equals("0")); ``` 最后,关闭Jedis连接: ```java jedis.close(); ``` 这样就完成了在Java中删除Redis中以特定key开头的数据的操作。记得在使用完Jedis后,要进行适当的资源释放和关闭连接。 需要注意的是,上述代码仅删除了以特定key开头的数据,并不会删除其他pattern匹配的数据。如果需要删除其他匹配模式的数据,可以根据需求修改`scanParams.match()`方法的参数。 它是通过使用SCAN命令的迭代方式在Redis中查找匹配的key,并逐个删除它们的方法。这种方法适用于大规模的Redis数据库,因为它避免了一次性遍历整个数据库的开销。 ### 回答2: Java删除Redis中以key开头的数据可以通过使用Redis的scan命令来实现。 首先,我们需要引入Jedis库来连接Redis服务器。然后,创建一个Jedis对象,并连接到Redis服务器。 接下来,我们可以使用scan命令来迭代Redis中的数据,并匹配以指定key开头的数据。使用scan命令是因为在Redis中没有提供原生的方法来按照key的规则来删除数据,而是需要迭代查找符合条件的key,并逐个进行删除操作。 具体操作如下: ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.ScanParams; import redis.clients.jedis.ScanResult; public class RedisKeyDeleteExample { public static void main(String[] args) { // 建立连接 Jedis jedis = new Jedis("localhost", 6379); // 设置要匹配的key String keyPattern = "key*"; // 初始化游标,从0开始 String cursor = "0"; // 设置scan参数 ScanParams scanParams = new ScanParams(); scanParams.match(keyPattern); do { // 执行scan命令 ScanResult<String> result = jedis.scan(cursor, scanParams); // 获取匹配的key列表 for (String key : result.getResult()) { // 删除匹配的key jedis.del(key); System.out.println("Deleted key: " + key); } // 获取下一个游标 cursor = result.getStringCursor(); } while (!cursor.equals("0")); // 关闭连接 jedis.close(); } } ``` 上述代码中,我们设置了要匹配的key模式为 "key*",然后使用scan命令逐页获取匹配的key列表,然后使用del命令逐个删除这些key。需要注意的是,在实际应用中,可能需要将该操作放在一个事务中来确保数据的一致性。 总结起来,以上就是Java删除Redis中以指定key开头的数据的方法。 ### 回答3: 在Java中删除Redis中以key开头的数据,可以通过使用Jedis客户端库来实现。 首先,我们需要创建一个Jedis连接对象,并连接到Redis服务器。可以使用以下代码: Jedis jedis = new Jedis("localhost", 6379); 接下来,我们可以使用keys模糊匹配功能来获取以key开头的所有键。可以使用以下代码: Set<String> keys = jedis.keys("key*"); 然后,我们可以遍历这些键,逐个删除它们对应的数据。可以使用以下代码: for (String key : keys) { jedis.del(key); } 最后,记得关闭Jedis连接以释放资源。可以使用以下代码: jedis.close(); 这样,以key开头的所有数据就会被成功删除了。 需要注意的是,使用keys命令进行模糊匹配可能会影响性能,尤其是在有大量键存在的情况下。如果你需要经常进行类似的操作,建议使用其他更高效的数据结构来组织你的数据,以便更方便地进行删除操作,例如使用Hash数据结构来存储以key开头的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值