jedisCluster模式下使用scan命令来删除指定前缀的字符串

因业务需要,需要对指定redis的前缀批量删除,如果直接使用keys 命令在数据量比较大的情况下会导致redis集群崩溃或者业务hang住。利用scan通过分页方式来拿到指定的key前缀,在进行相关数据的删除。

之前搜了网上很多文章,发现jedisCluster.getClusterNodes()在jedis的4.x版本获取的对象Map<String, ConnectionPool>,而不是Map<String, JedisPool>。针对这个情况进行代码改造

Connection jedisConnect = pool.getResource();

Jedis jedisNode = new Jedis(jedisConnect);

来获取jedisNode客户段,具体代码如下

public void delStringByScanV2(String keyPrefix) {

        ScanParams scanParams = new ScanParams().match(keyPrefix + "*").count(50);
        redisService.getJedis().getClusterNodes().values().stream()
        .forEach(pool -> {
            boolean done = false;
            String cursor = SCAN_POINTER_START;
            try (Connection jedisConnect = pool.getResource(); Jedis jedisNode = new Jedis(jedisConnect)) {
                while (!done) {
                    ScanResult<String> resp = jedisNode.scan(cursor, scanParams);

                    log.info("Key: " + resp.getResult() + ", Value: " + resp.getCursor() +",cluster: " + pool.getResource().toString());
                    //删除redis的key
                    resp.getResult().stream().map(key -> redisService.getJedis().del(key)).count();
                    cursor = resp.getCursor();
                    if (SCAN_POINTER_START.equals(cursor)) {
                        done = true;
                    }
                }
            }
        });
    }

其中getJedis返回的是 JedisCluster

 public JedisCluster getJedis() {
        if (jedis == null) {
            logger.info("Jedis connection is lost, need to reconnect " + redisNodes);
            createRedisConn();
        }
        return jedis;
    }

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值