在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 限制内存使用大小的实现
May 08 Redis
Redis数据结构之链表与字典的使用
May 11 Redis
为Java项目添加Redis缓存的方法
May 18 Redis
比较几种Redis集群方案
Jun 21 Redis
关于redisson缓存序列化几枚大坑说明
Aug 04 Redis
redis缓存存储Session原理机制
Nov 20 Redis
Springboot/Springcloud项目集成redis进行存取的过程解析
Dec 04 Redis
linux下安装redis图文详细步骤
Dec 04 Redis
分布式架构Redis中有哪些数据结构及底层实现原理
Mar 13 Redis
redis数据一致性的实现示例
Mar 18 Redis
sentinel支持的redis高可用集群配置详解
Apr 01 Redis
Redis如何实现验证码发送 以及限制每日发送次数
Apr 18 Redis
Redis集群的关闭与重启操作
Jul 07 #Redis
redis不能访问本机真实ip地址的解决方案
Jul 07 #Redis
redis客户端实现高可用读写分离的方式详解
使用Redis实现实时排行榜功能
Jul 02 #Redis
redis使用不当导致应用卡死bug的过程解析
Redis主从配置和底层实现原理解析(实战记录)
浅谈Redis中的RDB快照
You might like
PHP+MYSQL 出现乱码的解决方法
2008/08/08 PHP
PHP网站备份程序代码分享
2011/06/10 PHP
php对象在内存中的存在形式分析
2015/02/03 PHP
php实现俄罗斯乘法实例
2015/03/07 PHP
Yii2实现多域名跨域同步登录退出
2017/02/04 PHP
Thinkphp 空操作、空控制器、命名空间(详解)
2017/05/05 PHP
[原创]php token使用与验证示例【测试可用】
2017/08/30 PHP
PHP大文件分割分片上传实现代码
2020/12/09 PHP
javascript 主动派发事件总结
2011/08/09 Javascript
js复制网页内容并兼容各主流浏览器的代码
2013/12/17 Javascript
javaScript中的this示例学习详解及工作原理
2014/01/13 Javascript
jquery datepicker参数介绍和示例
2014/04/15 Javascript
jQuery+ajax+asp.net获取Json值的方法
2016/06/08 Javascript
基于bootstrap的选择框插件icheck
2016/12/23 Javascript
ajax图片上传,图片异步上传,更新实例
2016/12/30 Javascript
移动前端图片压缩上传的实例
2017/12/06 Javascript
jQuery AJAX 方法success()后台传来的4种数据详解
2018/08/08 jQuery
vue中slot(插槽)的介绍与使用
2018/11/12 Javascript
nuxt中使用路由守卫的方法步骤
2019/01/27 Javascript
如何在Angular8.0下使用ngx-translate进行国际化配置
2019/07/24 Javascript
vant 解决tab切换插件标题样式自定义的问题
2020/11/13 Javascript
记录一次websocket封装的过程
2020/11/23 Javascript
go和python调用其它程序并得到程序输出
2014/02/10 Python
搭建python django虚拟环境完整步骤详解
2019/07/08 Python
python实现登录密码重置简易操作代码
2019/08/14 Python
对Python 中矩阵或者数组相减的法则详解
2019/08/26 Python
Python调用shell命令常用方法(4种)
2020/05/11 Python
Flask处理Web表单的实现方法
2021/01/31 Python
CSS3.0实现霓虹灯按钮动画特效的示例代码
2021/01/12 HTML / CSS
爱普生美国官网:Epson美国
2018/11/05 全球购物
一组SQL面试题
2016/02/15 面试题
高等教育学自荐书范文
2014/02/10 职场文书
幼儿园母亲节活动方案
2014/03/10 职场文书
Python 发送SMTP邮件的简单教程
2021/06/24 Python
Python Matplotlib绘制等高线图与渐变色扇形图
2022/04/14 Python
分享python函数常见关键字
2022/04/26 Python