jedis運用scan刪除正則匹配的key
我們都知道用keys *進行查詢key的時候會進行堵塞,導致redis整體不可用,而使用scan命令則不會.
RedisServiceImpl中scan的內容為
@Override
public ScanResult scan(String cursor, ScanParams params) {
return execute(new RedisFunction<ScanResult, Jedis>() {
@Override
public ScanResult callback(Jedis jedis) {
return jedis.scan(cursor,params);
}
});
}
然后定義一個工具類
public class RedisUntil {
public static List<String> getScan(RedisService redisService,String key) {
List<String> list = new ArrayList<>();
ScanParams params = new ScanParams();
params.match(key);
params.count(100);
while (true) {
ScanResult scanResult = redisService.scan("0",params);
List<String> elements = scanResult.getResult();
if (elements != null && elements.size() > 0) {
list.addAll(elements);
}
String cursor = scanResult.getStringCursor();
if ("0".equals(cursor)) {
break;
}
}
return list;
}
}
使用該工具類進行批量刪除,假設我們要刪除的是以"userpage:"為前綴
List<String> keyList = RedisUntil.getScan(redisService,"userpage:*");
for (String key:keyList) {
redisService.del(key);
}