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

溫馨提示×

溫馨提示×

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

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

Springboot 如何使用本地緩存Caffeine

發布時間:2020-11-17 14:04:12 來源:億速云 閱讀:1100 作者:Leah 欄目:開發技術

本篇文章為大家展示了Springboot 如何使用本地緩存Caffeine,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

Caffeine是使用Java8對Guava緩存的重寫版本性能有很大提升

一 依賴

<dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-cache</artifactId>
    </dependency>
    <!-- caffeine -->
    <dependency>
      <groupId>com.github.ben-manes.caffeine</groupId>
      <artifactId>caffeine</artifactId>
      <version>2.7.0</version>
    </dependency>

二 配置緩存,單獨使用

只需要配置Bean就可以了,然后進行數據讀寫,注意這里提供了很多強大的自定義配置,可以查看文檔詳細配置

//定義緩存,可直接使用
  @Bean
  public LoadingCache expiryCache(){
    LoadingCache<String, Object> loadingCache = Caffeine.newBuilder()
        .initialCapacity(100)
        .maximumSize(1000)
        //緩存寫入/刪除監控
        .writer(new CacheWriter<Object, Object>() {
          @Override
          public void write(Object key, Object value) { //此方法是同步阻塞的
            System.out.println("--緩存寫入--:key=" + key + ", value=" + value);
          }
          @Override
          public void delete(Object key, Object value, RemovalCause cause) { System.out.println("--緩存刪除--:key=" + key); }
        })
        .expireAfterAccess(1, TimeUnit.MINUTES) //過期時間
        .build((String key)->"刷新的數據"); //cacheload實現類,刷新時候調用
    loadingCache.put("name","侯征");
    return loadingCache;
  }

測試使用:

@Autowired
  private LoadingCache loadingCache;
  @GetMapping("/get")
  public Object getValue(String key){
    return loadingCache.get(key);
  }
  @GetMapping("/add")
  public void addValue(String value){
    loadingCache.put(value,value);
  }
  @GetMapping("/delete")
  public void deleteValue(String key){
    loadingCache.invalidate(key);
    loadingCache.invalidateAll();//清楚所有
  }
  @GetMapping("/refresh")
  public void refreshValue(String key){
    //刷新時會根據build方法中中指定的cacheload重新加載
    loadingCache.refresh(key);
  }

三 配置CacheManager,和spring緩存注解一起使用

//配置CacheManager
  @Bean(name = "caffeine")
  public CacheManager cacheManagerWithCaffeine() {
    CaffeineCacheManager cacheManager = new CaffeineCacheManager();
    Caffeine caffeine = Caffeine.newBuilder()
        //cache的初始容量值
        .initialCapacity(100)
        //maximumSize用來控制cache的最大緩存數量,maximumSize和maximumWeight(最大權重)不可以同時使用,
        .maximumSize(1000)
        //最后一次寫入或者訪問后過久過期
        .expireAfterAccess(500, TimeUnit.SECONDS)
        //創建或更新之后多久刷新,需要設置cacheLoader
        .refreshAfterWrite(10, TimeUnit.SECONDS);
    cacheManager.setCaffeine(caffeine);
    cacheManager.setCacheLoader(cacheLoader);
    cacheManager.setCacheNames(names);//根據名字可以創建多個cache,但是多個cache使用相同的策略
    cacheManager.setAllowNullValues(false);//是否允許值為空
    return cacheManager;
  }

配置 cacheload

/**
   * 必須要指定這個Bean,refreshAfterWrite配置屬性才生效
   */
  @Bean
  public CacheLoader<Object, Object> cacheLoader() {
    return new CacheLoader<Object, Object>() {
      @Override
      public Object load(Object key) throws Exception { return null;}
      // 重寫這個方法將oldValue值返回回去,進而刷新緩存
      @Override
      public Object reload(Object key, Object oldValue) throws Exception {
        System.out.println("--refresh--:"+key);
        return oldValue;
      }
    };
  }

其他就是在service中配置spring的幾個緩存注解使用就行了,這里放一張截圖,這些注解用法,網上很多:[/code]

Springboot 如何使用本地緩存Caffeine

上述內容就是Springboot 如何使用本地緩存Caffeine,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

漳平市| 郸城县| 昌宁县| 河津市| 根河市| 邢台市| 垫江县| 英山县| 栾城县| 扎囊县| 东港市| 伊吾县| 郑州市| 拉萨市| 大庆市| 新乡县| 定边县| 定兴县| 新田县| 泽库县| 日喀则市| 故城县| 鹿邑县| 宁南县| 手游| 共和县| 凯里市| 英山县| 庐江县| 兰考县| 龙游县| 沁源县| 临潭县| 灵宝市| 林甸县| 墨脱县| 栖霞市| 鄂伦春自治旗| 巴林左旗| 科技| 亳州市|