• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    在redisCluster中模糊获取key方式

    在一个集群中,显然不能通过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);
                ScanResultString> result = jedisCluster.scan("0", scanParams);
                ListString> 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 {
            MapString, JedisPool> clusterNodes = jedisCluster.getClusterNodes();
            for (Map.EntryString, JedisPool> entry : clusterNodes.entrySet()) {
                Jedis jedis = entry.getValue().getResource();
                // 判断非从节点(因为若主从复制,从节点会跟随主节点的变化而变化)
                if (!jedis.info("replication").contains("role:slave")) {
                    SetString> keys = jedis.keys(redisKeyStartWith + "*");
                    if (keys.size() > 0) {
                        MapInteger, ListString>> 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.EntryInteger, ListString>> 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 *

    查询结果示例:

    redis集群查所有key命令:

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

    正确的命令是

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

    注意:

    1.不能去掉\;

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

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

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

    您可能感兴趣的文章:
    • Java使用RedisTemplate模糊删除key操作
    • Spring Boot集成redis,key自定义生成方式
    • redis 查看所有的key方式
    • Springboot Redis设置key前缀的方法步骤
    • Redis遍历所有key的两个命令(KEYS 和 SCAN)
    • redis keys与scan命令的区别说明
    • redis通过lua脚本,获取满足key pattern的所有值方式
    上一篇:Redis集群的关闭与重启操作
    下一篇:Redis 彻底禁用RDB持久化操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    在redisCluster中模糊获取key方式 在,redisCluster,中,模糊,获取,