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); }}
阅读全文
0 0
- Redis命令用scan代替keys、smembers等命令
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- redis keys 命令
- Redis keys命令
- Redis keys 基本命令
- 3.Redis keys 命令
- Redis keys 键命令
- redis--keys命令
- Redis keys 命令
- redis之scan命令
- redis keys && scan
- redis的一些性能测试,主要是keys和smembers
- Redis命令之KEYS&MIGRATE
- Redis笔记2:keys命令
- redis keys命令 (24个)
- Redis命令(一)基本keys操作命令
- QT readline()
- LATEX常用语法
- 分享精心收藏的前台开发素材网站,都是干货
- 错误 ORA-01102: cannot mount database in EXCLUSIVE mode
- 各领域公开数据集下载
- Redis命令用scan代替keys、smembers等命令
- vue中修改了数据但视图无法更新的情况
- SpringBoot构建微服务实战 之 @Import
- Java命名规范
- 双向链表(一)
- linux配置ssl
- [Leetcode] 472. Concatenated Words 解题报告
- java调用C++的dll遇到问题
- QT 为可执行程序添加图标ico