爱收集资源网

玩转Redis集群,查询方法与方案揭秘

网络整理 2023-09-27 18:02

在一个集群中模糊集合的表示方法,恐怕不能通过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 result = jedisCluster.scan("0", scanParams);
            List 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 clusterNodes = jedisCluster.getClusterNodes();
        for (Map.Entry entry : clusterNodes.entrySet()) {
            Jedis jedis = entry.getValue().getResource();
            // 判断非从节点(因为若主从复制,从节点会跟随主节点的变化而变化)
            if (!jedis.info("replication").contains("role:slave")) {
                Set keys = jedis.keys(redisKeyStartWith + "*");
                if (keys.size() > 0) {
                    Map> 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> 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--clustercall192.168.168.161:7001keys*

注意:

1.不能去除;

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

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

以上为个人经验,希望能给你们一个参考,也希望你们多多支持云海天教程。

模糊集合的表示方法
上一篇:集成电路技术人员定义 下一篇:没有了