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