redis獲取所有key的方法
keys:全量遍歷鍵,用來列出所有滿足特定正則字符串規(guī)則的key,假設(shè)redis此時正在生產(chǎn)環(huán)境下,使用該命令就會造成隱患,當redis數(shù)據(jù)量比較大時:
keys會一次性返回所有符合條件的key,所以會造成redis的卡頓。
SCAN是一個基于游標的迭代器,需要基于上一次的游標延續(xù)之前的迭代過程。SCAN以0作為游標,開始一次新的迭代,直到命令返回游標0完成一次遍歷。
此命令并不保證每次執(zhí)行都返回某個給定數(shù)量的元素,甚至會返回0個元素,但只要游標不是0,程序都不會認為SCAN命令結(jié)束,但是返回的元素數(shù)量大概率符合count參數(shù)。另外,SCAN支持模糊查詢。
1.keys cmos-cache包
redisCacheService.keys(String pattern);
2.scan方法
public static Set<String> getAllKey(String match,int count){
//返回集
Set<String> binKeys = new HashSet<>();
//封裝scan查詢參數(shù)
ScanParams param = new ScanParams().match(match).count(count);
//獲取查詢對象
RedisCacheServiceImpl redisCacheSer = (RedisCacheServiceImpl)RedisCacheService;
JedisCluster jedisClu = redisCacheSer.getJedisCluster();
//getClueterNodes獲取集群節(jié)點,從各個集群中獲取值進行遍歷
jedisClu.getClusterNodes().values().stream().forEach(pool->{
boolean done = false;//
String cur = "0";//游標,以0開始,返回0代表一次結(jié)束
try(Jedis jedisNode = pool.getResource()){
while(!done){
ScanResult<String> scanResult = jedisNode.scan(cur,param);
cur = scanResult.getStringCursor();
if("0".equals(cur){done=true};
List<String> result = scanResult.getResult();
result.foreach(data->{binKeys.add(data)});
}
}
});
return binKeys;
}到此這篇關(guān)于redis獲取所有key的方法的文章就介紹到這了,更多相關(guān)redis獲取所有key內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis數(shù)據(jù)類型string和Hash詳解
大家都知道Redis中有五大數(shù)據(jù)類型分別是String、List、Set、Hash和Zset,本文給大家分享Redis數(shù)據(jù)類型string和Hash的相關(guān)操作,感興趣的朋友跟隨小編一起看看吧2022-03-03

