Redis命令用scan代替keys、smembers等命令

6 篇文章 0 订阅

附SCAN——Redis命令参考http://redisdoc.com/key/scan.html


keys、smembers等Redis命令会一次性扫描所有记录,如果redis数据量非常大,会影响redis性能,不适合用于生产环境。redis2.8版本以后有了一个新命令scan,可以用来分批次扫描redis记录,这样肯定会导致整个查询消耗的总时间变大,但不会影响redis服务卡顿,影响服务使用。


本文仅以scan对keys命令的替换为例,代码如下:

/**
 * 模糊匹配
 * @param pattern key的正则表达式
 * @param count 每次扫描多少条记录,值越大消耗的时间越短,但会影响redis性能。建议设为一千到一万
 * @return 匹配的key集合
    */
public static List<String> scan(String pattern, int count){
   List<String> list = new ArrayList<>();

   Jedis jedis = getJedis();
   if (jedis == null){
      return list;
   }

   try{
      String cursor = ScanParams.SCAN_POINTER_START;

      ScanParams scanParams = new ScanParams();
      scanParams.count(count);
      scanParams.match(pattern);

      do {
         ScanResult<String> scanResult = jedis.scan(cursor, scanParams);
         list.addAll(scanResult.getResult());
         cursor = scanResult.getStringCursor();
      }while(!"0".equals(cursor));

   return list;
   }catch(Exception e){
      log.error("",e);
      jedisPoolUtil.returnBrokenJedis(jedis);
      return list;
   }finally{
      jedisPoolUtil.returnJedis(jedis);
   }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值