中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在redisCluster中模糊獲取key方式

發布時間:2021-07-07 17:19:50 來源:億速云 閱讀:247 作者:chen 欄目:開發技術

本篇內容介紹了“如何在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);
            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方式

“如何在redisCluster中模糊獲取key方式”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

定日县| 黎城县| 宽城| 德化县| 临猗县| 岐山县| 板桥市| 资兴市| 太原市| 安陆市| 汝南县| 竹北市| 诸城市| 楚雄市| 涞源县| 桐庐县| 遂平县| 嘉鱼县| 万源市| 璧山县| 通许县| 南乐县| 龙江县| 五寨县| 吐鲁番市| 临桂县| 砚山县| 茶陵县| 镇平县| 泰和县| 长沙市| 明光市| 广灵县| 蒲江县| 泰州市| 柞水县| 赣州市| 吐鲁番市| 乌海市| 青河县| 无为县|