在一個集群中,顯然不能通過keys方法通過pattern直接獲取key的集合;
鑒于這種問題,產生了兩種思路,如下:
方案1:
已知相同的tag的kv會在一個節點上,所以只要key帶有相同的hashtag,則會在一個節點上,所以只要掃描該節點即可,這樣就將集群轉化為了單點。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
@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 { } } |
1
2
|
//scanparams.match("*{zmc}*");//success //scanparams.match("zmc_text:{zmc}*");//success |
上述match方法中:括號中的參數也可以按照如上方式編寫;
其關鍵在于 key 上傳到redis中,命名方式里面,必須含有 {};
并且{}前面、后面有無參數必須指定;若key為 zmc_text: {zmc}:1
1
|
scanparams.match( "{zmc}*" );查不出結果 |
方案2:
獲取所有的節點,分別掃描每個節點,根據pattern獲取節點中的key,整合起來即可;
注意:cluster模式執行多key操作的時候,這些key必須在同一個slot上,不然會報jedisdataexception異常;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
@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 *
查詢結果示例:
redis集群查所有key命令:
如果使用keys *,那么查詢的仍舊是本服務器的所有key,不是集群的(結合本圖結果以及參考上圖,都是插入后查詢,無心插入或者刪除key)
正確的命令是
./redis-cli -c --cluster call 192.168.168.161:7001 keys \*
注意:
1.不能去掉\;
2.換成你redis集群的一個節點的ip和端口
3.如果集群有密碼加上參數 -a password(你的redis集群密碼) 如本地測試環境查詢結果:
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/qq_33999844/article/details/81381607