场景:
最近做业务,有涉及到批量删除redis中的缓存数据,经过网上查找,自己测试,得出了根据key前缀,批量删除redis缓存的方法,话不多说,直接上代码。
代码:
/**
* 根据key前缀批量删除缓存
* @param key
* @return
*/
public static long batchDel(String key){
long result = 0;
Jedis jedis = null;
try {
jedis = getResource();
Set<String> set = jedis.keys(key +"*");
Iterator<String> it = set.iterator();
while(it.hasNext()){
String keyStr = it.next();
System.out.println(keyStr);
result += jedis.del(keyStr);
}
} catch (Exception e){
} finally {
returnResource(jedis);
}
return result;
}
其中 getResource() 方法是获取redis对象,returnResource() 是回收redis对象。
调用方法:
batchDel("指定的key前缀");
例:
当前我的redis中有key 前缀为 model_Cache:Fixed: 的缓存共 8 条【如上图】,执行批量删除方法 batchDel("model_Cache:Fixed:"); 原来的model_Cache下的缓存数量变成0,批量删除成功。