在redisCluster中模糊获取key方式


Posted in Redis onJuly 09, 2021

在一个集群中,显然不能通过keys方法通过pattern直接获取key的集合;

鉴于这种问题,产生了两种思路,如下:

方案1:

已知相同的tag的KV会在一个节点上,所以只要key带有相同的hashtag,则会在一个节点上,所以只要扫描该节点即可,这样就将集群转化为了单点。

@RequestMapping(value = "/ceshi", method = RequestMethod.GET)
    @ResponseBody
    public void Rediskeys() {
        /**
         * 模糊匹配
         * @param pattern key的正则表达式
         * @param count 每次扫描多少条记录,值越大消耗的时间越短,但会影响redis性能。建议设为一千到一万
         * @return 匹配的key集合
         */
        try{
            jedisCluster.getClusterNodes();
            ScanParams scanParams = new ScanParams();
            scanParams.match("{operatingSystem}*");
            scanParams.count(1000);
            ScanResult<String> result = jedisCluster.scan("0", scanParams);
            List<String> keyList = result.getResult();
            System.out.println("keyList======="+keyList);
        }finally{
        }
    }
//scanParams.match("*{zmc}*");//success
//scanParams.match("ZMC_text:{zmc}*");//success

上述match方法中:括号中的参数也可以按照如上方式编写;

其关键在于 key 上传到redis中,命名方式里面,必须含有 {};

并且{}前面、后面有无参数必须指定;若key为 ZMC_text: {zmc}:1

scanParams.match("{zmc}*");查不出结果

方案2:

获取所有的节点,分别扫描每个节点,根据pattern获取节点中的key,整合起来即可;

注意:cluster模式执行多key操作的时候,这些key必须在同一个slot上,不然会报JedisDataException异常;

@RequestMapping(value = "/ceshi3", method = RequestMethod.GET)
@ResponseBody
public void RedisKeys() {
    String redisKeyStartWith="Ad:ads:id:";
    try {
        Map<String, JedisPool> clusterNodes = jedisCluster.getClusterNodes();
        for (Map.Entry<String, JedisPool> entry : clusterNodes.entrySet()) {
            Jedis jedis = entry.getValue().getResource();
            // 判断非从节点(因为若主从复制,从节点会跟随主节点的变化而变化)
            if (!jedis.info("replication").contains("role:slave")) {
                Set<String> keys = jedis.keys(redisKeyStartWith + "*");
                if (keys.size() > 0) {
                    Map<Integer, List<String>> map = new HashMap<>();
                    for (String key : keys) {
                        // cluster模式执行多key操作的时候,这些key必须在同一个slot上,不然会报:JedisDataException:
                        // CROSSSLOT Keys in request don't hash to the same slot
                        int slot = JedisClusterCRC16.getSlot(key);
                        // 按slot将key分组,相同slot的key一起提交
                        if (map.containsKey(slot)) {
                            map.get(slot).add(key);
                        } else {
                            map.put(slot, Lists.newArrayList(key));
                        }
                    }
                    for (Map.Entry<Integer, List<String>> integerListEntry : map.entrySet()) {
                        System.out.println("integerListEntry="+integerListEntry);
                        //jedis.del(integerListEntry.getValue().toArray(new String[integerListEntry.getValue().size()]));
                    }
                }
            }
        }
        logger.info("success redisKeys:{}", redisKeyStartWith);
    } finally {
    }
}

redis集群获取所有的key

redis单机查询所有key命令

keys *

查询结果示例:

在redisCluster中模糊获取key方式

redis集群查所有key命令:

如果使用keys *,那么查询的仍旧是本服务器的所有key,不是集群的(结合本图结果以及参考上图,都是插入后查询,无心插入或者删除key)

正确的命令是

./redis-cli -c --cluster call 192.168.168.161:7001 keys \*

注意:

1.不能去掉\;

2.换成你redis集群的一个节点的ip和端口

3.如果集群有密码加上参数 -a password(你的redis集群密码) 如本地测试环境查询结果:

在redisCluster中模糊获取key方式

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Redis 相关文章推荐
浅谈redis五大数据结构和使用场景
Apr 12 Redis
详解Redis主从复制实践
May 19 Redis
Redis的字符串是如何实现的
Oct 24 Redis
解决Redis启动警告问题
Feb 24 Redis
redis数据一致性的实现示例
Mar 18 Redis
Redis集群节点通信过程/原理流程分析
Mar 18 Redis
Redis数据同步之redis shake的实现方法
Apr 21 Redis
Redis高并发缓存架构性能优化
May 15 Redis
Redis 限流器
May 15 Redis
Redis 异步机制
May 15 Redis
浅谈Redis变慢的原因及排查方法
Jun 21 Redis
Redis集群的关闭与重启操作
Jul 07 #Redis
redis不能访问本机真实ip地址的解决方案
Jul 07 #Redis
redis客户端实现高可用读写分离的方式详解
使用Redis实现实时排行榜功能
Jul 02 #Redis
redis使用不当导致应用卡死bug的过程解析
Redis主从配置和底层实现原理解析(实战记录)
浅谈Redis中的RDB快照
You might like
自己做矿石收音机
2021/03/02 无线电
分享3个php获取日历的函数
2015/09/25 PHP
js事件冒泡实例分享(已测试)
2013/04/23 Javascript
javascript动态设置样式style实例分析
2015/05/13 Javascript
基于javascript实现简单计算器功能
2016/01/03 Javascript
JS作用域闭包、预解释和this关键字综合实例解析
2016/12/16 Javascript
前端分页功能的实现以及原理(jQuery)
2017/01/22 Javascript
基于AGS JS开发自定义贴图图层
2017/03/31 Javascript
vue学习笔记之指令v-text &amp;&amp; v-html &amp;&amp; v-bind详解
2017/05/12 Javascript
JavaScript手风琴页面制作
2017/05/17 Javascript
详解Angular CLI + Electron 开发环境搭建
2017/07/20 Javascript
Node之简单的前后端交互(实例讲解)
2017/11/14 Javascript
vue.js图片转Base64上传图片并预览的实现方法
2018/08/02 Javascript
vue 关闭浏览器窗口的时候,清空localStorage的数据示例
2019/11/06 Javascript
[55:03]LGD vs EG 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
[01:07:53]RNG vs VG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python的Django框架中的表单处理示例
2015/07/17 Python
python reduce 函数使用详解
2017/12/05 Python
Python socket模块ftp传输文件过程解析
2019/11/05 Python
python对象销毁实例(垃圾回收)
2020/01/16 Python
python+Selenium自动化测试——输入,点击操作
2020/03/06 Python
python不到50行代码完成了多张excel合并的实现示例
2020/05/28 Python
python安装第三方库如xlrd的方法
2020/10/31 Python
HTML5自定义data-* data(obj)属性和jquery的data()方法的使用
2012/12/13 HTML / CSS
HTML5 Canvas 绘图——使用 Canvas 绘制图形图文教程 使用html5 canvas 绘制精美的图
2015/08/31 HTML / CSS
全球酒店预订网站:Hotels.com
2016/08/10 全球购物
英国领先的瓷砖专家:Walls and Floors
2018/04/27 全球购物
Order by的几种用法
2013/06/16 面试题
软件设计的目标是什么
2016/12/04 面试题
高级文秘工作总结的自我评价
2013/09/28 职场文书
销售辞职报告范文
2014/01/12 职场文书
员工评语大全
2014/01/19 职场文书
2019让人心动的商业计划书
2019/06/27 职场文书
导游词之云南丽江-泸沽湖
2019/09/26 职场文书
Python爬虫之用Xpath获取关键标签实现自动评论盖楼抽奖(二)
2021/06/07 Python
Java Dubbo框架知识点梳理
2021/06/26 Java/Android