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

来源:互联网 发布:华为双卡切换网络数据 编辑:程序博客网 时间:2024/06/06 20:41

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

原创粉丝点击