Jedis运用scan删除正则匹配的key

本文介绍了如何使用Redis的Scan命令来避免在批量操作时造成服务堵塞,通过一个实用的工具类示例展示了如何实现批量删除带有特定前缀的键。

我们都知道用keys *进行查询key的时候会进行堵塞,导致redis整体不可用,而使用scan命令则不会.

RedisServiceImpl中scan的内容为

@Override
public ScanResult scan(String cursor, ScanParams params) {
    return execute(new RedisFunction<ScanResult, Jedis>() {

        @Override
        public ScanResult callback(Jedis jedis) {
            return jedis.scan(cursor,params);
        }

    });
}

然后定义一个工具类

public class RedisUntil {
    public static List<String> getScan(RedisService redisService,String key) {
        List<String> list = new ArrayList<>();
        ScanParams params = new ScanParams();
        params.match(key);
        params.count(100);
        String cursor = "0";
        while (true) {
            ScanResult scanResult = redisService.scan(cursor,params);
            List<String> elements = scanResult.getResult();
            if (elements != null && elements.size() > 0) {
                list.addAll(elements);
            }
            cursor = scanResult.getStringCursor();
            if ("0".equals(cursor)) {
                break;
            }
        }
        return list;
    }
}

使用该工具类进行批量删除,假设我们要删除的是以"userpage:"为前缀

List<String> keyList = RedisUntil.getScan(redisService,"userpage:*");
for (String key:keyList) {
    redisService.del(key);
}

这样在生产环境中就不会堵塞redis.

转载于:https://my.oschina.net/u/3768341/blog/1928380

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值