redis獲取所有key的方法
keys:全量遍歷鍵,用來列出所有滿足特定正則字符串規(guī)則的key,假設(shè)redis此時正在生產(chǎn)環(huán)境下,使用該命令就會造成隱患,當(dāng)redis數(shù)據(jù)量比較大時:
keys會一次性返回所有符合條件的key,所以會造成redis的卡頓。
SCAN是一個基于游標(biāo)的迭代器,需要基于上一次的游標(biāo)延續(xù)之前的迭代過程。SCAN以0作為游標(biāo),開始一次新的迭代,直到命令返回游標(biāo)0完成一次遍歷。
此命令并不保證每次執(zhí)行都返回某個給定數(shù)量的元素,甚至?xí)祷?個元素,但只要游標(biāo)不是0,程序都不會認(rèn)為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é)點,從各個集群中獲取值進(jìn)行遍歷 jedisClu.getClusterNodes().values().stream().forEach(pool->{ boolean done = false;// String cur = "0";//游標(biāo),以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