中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ehcache如何實現模糊批量移除緩存

發布時間:2021-08-04 14:41:25 來源:億速云 閱讀:139 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“ehcache如何實現模糊批量移除緩存”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“ehcache如何實現模糊批量移除緩存”這篇文章吧。

前言

眾所周知,encache是現在最流行的java開源緩存框架,配置簡單,結構清晰,功能強大。通過注解 @Cacheable 可以快速添加方法結果到緩存。通過 @CacheEvict 可以快速清除掉指定的緩存。

但由于 @CacheEvict 注解使用的是key-value的,不支持模糊刪除,就會遇到問題。當我用 @Cacheable 配合Spring EL表達式添加了同一方法的多個緩存比如:

@GetMapping("/listOfTask/{page}/")
@Cacheable(value = "BusinessCache", key = "'listOfTask_'+ #page")
public ResponseMessage<PageTaskVO> getTaskList(@PathVariable("page") String page) {
  do something...
}

上述代碼是分頁獲取任務信息。用EL表達式獲取到參數中的page,并作為緩存的key,使用 @Cacheable 添加到ehcache的緩存中。此時,在緩存中就會出現 listOfTask_1 , listOfTask_2 , listOfTask_3 這種類型的key。

當添加、刪除任務時,列表就會發生改變。這時候,就需要把 listOfTask_* 相關的緩存全部去掉。而這時,我不知道緩存中到底緩存了多少和 listOfTask_* 相關的內容,不可能調用 @CacheEvict 挨個刪除。

既然ehcache本身無法支持,那就只能靠我們自己實現了。

實現

考慮到使用的注解添加的緩存,那么移除緩存也使用注解處理,可以保持開發的一致性。注解對開發者來說也很友好。那么我們就考慮使用自定義注解來來模糊批量移除緩存。

首先,定義注解 CacheRemove :

@Target({ java.lang.annotation.ElementType.METHOD })
@Retention(RetentionPolicy.RUNTIME)
public @interface CacheRemove {
  String value();
  String[] key();
}

其中,value 同 ehcache 一樣,用于定義要操作的緩存名。key 是一個數組,用于存放多種緩存 key 的正則表達式。起名 CacheRemove 清晰易懂,也不與 ehcache 本身的注解沖突。注解的定義到此為止。接下來,就需要處理注解了,由于使用的 spring 框架,很自然的,就會想到用 AOP 來做注解的具體實現。

注解的目的是批量模糊移除緩存。需考慮如下兩個問題:

  1. 用什么方式模糊匹配

  2. 怎么批量刪除key

我給出的處理方式,也是我認為最簡單的處理方式是:

  1. 用什么方式模糊匹配 —— CacheRemove 中的key傳正則,可以傳多個,使用正則匹配

  2. 怎么批量刪除key —— 循環所有的key,找到匹配正則的就刪除

首先定義類名 CacheRemoveAspect :

@Aspect
@Component
public class CacheRemoveAspect {
  @Pointcut(value = "(execution(* *.*(..)) && @annotation(com.example.CacheRemove))")
  private void pointcut() {}

  do something...
}

在切面中定義切點,使用 execution(* *.*(..) && @annotation(com.example.CacheRemove)) 表示所有帶注解類 CacheRemove 都執行, @annotation 中的值是注解的全限定名。

切點定義完畢,下面的重頭戲就是切面的具體實現了。一般來說,緩存會在增刪改的方法執行完后才要移除。所以使用 @AfterReturning() 來實現。在具體實現中需要做以下幾件事:

  1. 攔截方法上的注解

  2. 判斷注解是不是 CacheRemove

  3. 由于注解傳入的 key 是個數組,循環處理每個key

  4. 在循環中編制每個 key 為 pattern, 并循環所有的緩存,移除匹配上的緩存

具體實現如下:

@AfterReturning(value = "pointcut()")
private void process(JoinPoint joinPoint){
  MethodSignature signature = (MethodSignature) joinPoint.getSignature();
  Method method = signature.getMethod();
  CacheRemove cacheRemove = method.getAnnotation(CacheRemove.class);

  if (cacheRemove != null){
    String value = cacheRemove.value();
    String[] keys = cacheRemove.key(); //需要移除的正則key

    List cacheKeys = CacheUtils.cacheKeys(value);
    for (String key : keys){
      Pattern pattern = Pattern.compile(key);
      for (Object cacheKey: cacheKeys) {
        String cacheKeyStr = String.valueOf(cacheKey);
        if (pattern.matcher(cacheKeyStr).find()){
          CacheUtils.remove(value, cacheKeyStr);
        }
      }
    }
  }
}

以上,為 ehcache 模糊批量移除緩存的具體實現。其中 BusinessCacheUtils 為自己封裝的 ehcache 工具類。主要實現獲取緩存池,獲取緩存,移除緩存,添加緩存,查看所有緩存等正常功能。代碼如下:

public class CacheUtils {

  private static CacheManager cacheManager = SpringContextHolder.getBean("ehCacheManagerFactory");

  public static Object get(String cacheName, String key) {
    Element element = getCache(cacheName).get(key);
    return element == null ? null : element.getObjectValue();
  }

  public static void put(String cacheName, String key, Object value) {
    Element element = new Element(key, value);
    getCache(cacheName).put(element);
  }

  public static void remove(String cacheName, String key) {
    getCache(cacheName).remove(key);
  }

  public static List cacheKeys(String cacheName){
    return getCache(cacheName).getKeys();
  }

  /**
   * 獲得一個Cache,沒有則創建一個。
   * @param cacheName
   * @return
   */
  private static Cache getCache(String cacheName) {
    Cache cache = cacheManager.getCache(cacheName);
    if (cache == null) {
      cacheManager.addCache(cacheName);
      cache = cacheManager.getCache(cacheName);
      cache.getCacheConfiguration().setEternal(true);
    }
    return cache;
  }

  public static CacheManager getCacheManager() {
    return cacheManager;
  }

}

至此,整個ehcache 模糊批量移除緩存的功能就實現了。

以上是“ehcache如何實現模糊批量移除緩存”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

沾益县| 昆山市| 定结县| 同心县| 万山特区| 安阳市| 晋中市| 高青县| 昭通市| 贡山| 呼和浩特市| 鲁甸县| 新田县| 个旧市| 天长市| 永吉县| 内乡县| 台前县| 哈密市| 长沙市| 通州区| 苏尼特左旗| 永德县| 涞源县| 兰西县| 武陟县| 凤凰县| 巴塘县| 德昌县| 岳阳市| 崇左市| 双牌县| 新郑市| 调兵山市| 宁津县| 高州市| 黄石市| 镇平县| 四川省| 杭州市| 建湖县|