当前位置:   article > 正文

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

redis smembers 用scan 替换

附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);
   }
}

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/735624
推荐阅读
相关标签
  

闽ICP备14008679号