场景:

      最近做业务,有涉及到批量删除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 redis根据前缀删除key_redis 删除前缀key

当前我的redis中有key 前缀为 model_Cache:Fixed: 的缓存共 8 条【如上图】,执行批量删除方法 batchDel("model_Cache:Fixed:"); 原来的model_Cache下的缓存数量变成0,批量删除成功。

redis 删除前缀key redis根据前缀删除key_缓存_02