您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“如何在redisCluster中模糊獲取key方式”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
在一個集群中,顯然不能通過keys方法通過pattern直接獲取key的集合;
已知相同的tag的KV會在一個節(jié)點上,所以只要key帶有相同的hashtag,則會在一個節(jié)點上,所以只要掃描該節(jié)點即可,這樣就將集群轉(zhuǎn)化為了單點。
@RequestMapping(value = "/ceshi", method = RequestMethod.GET) @ResponseBody public void Rediskeys() { /** * 模糊匹配 * @param pattern key的正則表達式 * @param count 每次掃描多少條記錄,值越大消耗的時間越短,但會影響redis性能。建議設(shè)為一千到一萬 * @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方法中:括號中的參數(shù)也可以按照如上方式編寫;
其關(guān)鍵在于 key 上傳到redis中,命名方式里面,必須含有 {};
并且{}前面、后面有無參數(shù)必須指定;若key為 ZMC_text: {zmc}:1
scanParams.match("{zmc}*");查不出結(jié)果
獲取所有的節(jié)點,分別掃描每個節(jié)點,根據(jù)pattern獲取節(jié)點中的key,整合起來即可;
注意:cluster模式執(zhí)行多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(); // 判斷非從節(jié)點(因為若主從復(fù)制,從節(jié)點會跟隨主節(jié)點的變化而變化) 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模式執(zhí)行多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命令
keys *
查詢結(jié)果示例:
如果使用keys *,那么查詢的仍舊是本服務(wù)器的所有key,不是集群的(結(jié)合本圖結(jié)果以及參考上圖,都是插入后查詢,無心插入或者刪除key)
正確的命令是
./redis-cli -c --cluster call 192.168.168.161:7001 keys \*
注意:
1.不能去掉\;
2.換成你redis集群的一個節(jié)點的ip和端口
3.如果集群有密碼加上參數(shù) -a password(你的redis集群密碼) 如本地測試環(huán)境查詢結(jié)果:
“如何在redisCluster中模糊獲取key方式”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。