日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

学习Spring Boot:(二十一)使用 EhCache 实现数据缓存

發布時間:2025/3/12 javascript 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 学习Spring Boot:(二十一)使用 EhCache 实现数据缓存 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

當多次查詢數據庫影響到系統性能的時候,可以考慮使用緩存,來解決數據訪問新能的問題。
SpringBoot 已經為我們提供了自動配置多個 CacheManager 的實現,只要去實現使用它就可以了。

一般的系統都是優先使用 EhCache,它工作在 JAVA 進程中,在傳統的應用沒有太大要求的時候,使用它比較方便,分布式系統中去使用 Shiro 集中管理緩存。

正文

加入依賴

在 pom.xml 中加入依賴

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-cache</artifactId></dependency><dependency><groupId>net.sf.ehcache</groupId><artifactId>ehcache</artifactId></dependency>

添加緩存相關的配置

新建 ehcache.xml,加入緩存相關參數, 我新添加一個 name 為 users 的緩存設置:

<?xml version="1.0" encoding="UTF-8"?> <ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd"updateCheck="false"><diskStore path="java.io.tmpdir/Tmp_EhCache"/><defaultCachemaxElementsInMemory="1000"maxEntriesLocalHeap="400"eternal="false"timeToIdleSeconds="120"timeToLiveSeconds="120"overflowToDisk="false"diskPersistent="false"diskExpiryThreadIntervalSeconds="120"/><cachename="users"maxEntriesLocalHeap="200"timeToLiveSeconds="600"/></ehcache>

參數詳解:

  • name:緩存名稱。
  • maxElementsInMemory:緩存最大個數。
  • eternal:對象是否永久有效,一但設置了,timeout將不起作用。
  • timeToIdleSeconds:設置對象在失效前的允許閑置時間(單位:秒)。僅當eternal=false對象不是永久有效時使用,可選屬性,默認值是0,也就是可閑置時間無窮大。
  • timeToLiveSeconds:設置對象在失效前允許存活時間(單位:秒)。最大時間介于創建時間和失效時間之間。僅當eternal=false對象不是永久有效時使用,默認是0.,也就是對象存活時間無窮大。
  • overflowToDisk:當內存中對象數量達到maxElementsInMemory時,Ehcache將會對象寫到磁盤中。
  • diskSpoolBufferSizeMB:這個參數設置DiskStore(磁盤緩存)的緩存區大小。默認是30MB。每個Cache都應該有自己的一個緩沖區。
  • maxElementsOnDisk:硬盤最大緩存個數。
  • diskPersistent:是否緩存虛擬機重啟期數據,默認為false。
  • diskExpiryThreadIntervalSeconds:磁盤失效線程運行時間間隔,默認是120秒。
  • memoryStoreEvictionPolicy:當達到maxElementsInMemory限制時,Ehcache將會根據指定的策略去清理內存。默認策略是LRU(最近最少使用)。你可以設置為FIFO(先進先出)或是LFU(較少使用)。
  • clearOnFlush:內存數量最大時是否清除。
  • memoryStoreEvictionPolicy:當達到maxElementsInMemory限制時,Ehcache將會根據指定的策略去清理內存。默認策略是LRU(最近最少使用)。你可以設置為FIFO(先進先出)或是LFU(較少使用)。

開啟緩存

  • 在系統配置文件中指定
    在配置文件中加入指定我們設置的 ehcache.xml 作為 EhCache 的配置文件:
  • spring:cache:ehcache:config: config/ehcache.xml # 指定 ehcache.xml 創建EhCache的緩存管理器type: ehcache # 指定緩存管理器
  • 在啟動類上加上注解 @EnableCaching,開啟緩存。
  • 使用

    使用的時候需要注意,我們之前在 shiro 緩存中 配置了相關的緩存的配置,現在需要把 shiro 相關的緩存的內容全部都要刪除掉,不然兩者的緩存會存在沖突。
    還是以 shiro 的獲取權限列表的服務為例,不用 shiro-cache 后,直接在查詢的這里自己添加上緩存就可以了。

    @CacheConfig(cacheNames = "users") public interface ShiroService {/*** 獲取用戶權限** @param userId 用戶ID* @return 權限*/@CacheableSet<String> getUserPermissions(long userId);

    debug 調試,

    @Autowired private CacheManager cacheManager;

    發現 key 為 users 中存儲了相關內容。

    注解的使用

    • @CacheConfig:主要用于配置該類中會用到的一些共用的緩存配置。在這里@CacheConfig(cacheNames = "users"):配置了該數據訪問對象中返回的內容將存儲于名為users的緩存對象中,我們也可以不使用該注解,直接通過@Cacheable自己配置緩存集的名字來定義。

    • @Cacheable:配置了

      getUserPermissions(long userId)

      函數的返回值將被加入緩存。同時在查詢時,會先從緩存中獲取,若不存在才再發起對數據庫的訪問。該注解主要有下面幾個參數:

    • value、cacheNames:兩個等同的參數(cacheNames為Spring 4新增,作為value的別名),用于指定緩存存儲的集合名。由于Spring 4中新增了@CacheConfig,因此在Spring 3中原本必須有的value屬性,也成為非必需項了。
    • key:緩存對象存儲在Map集合中的key值,非必需,缺省按照函數的所有參數組合作為key值,若自己配置需使用SpEL表達式,比如:@Cacheable(key = "#p0"):使用函數第一個參數作為緩存的key值,更多關于SpEL表達式的詳細內容可參考官方文檔
    • condition:緩存對象的條件,非必需,也需使用SpEL表達式,只有滿足表達式條件的內容才會被緩存,比如:@Cacheable(key = "#p0", condition = "#p0.length() < 3"),表示只有當第一個參數的長度小于3的時候才會被緩存,
    • unless:另外一個緩存條件參數,非必需,需使用SpEL表達式。它不同于condition參數的地方在于它的判斷時機,該條件是在函數被調用之后才做判斷的,所以它可以通過對result進行判斷。
    • keyGenerator:用于指定key生成器,非必需。若需要指定一個自定義的key生成器,我們需要去實現org.springframework.cache.interceptor.KeyGenerator接口,并使用該參數來指定。需要注意的是:該參數與key是互斥的。
    • cacheManager:用于指定使用哪個緩存管理器,非必需。只有當有多個時才需要使用。
    • cacheResolver:用于指定使用那個緩存解析器,非必需。需通過org.springframework.cache.interceptor.CacheResolver接口來實現自己的緩存解析器,并用該參數指定。

    除了這里用到的兩個注解之外,還有下面幾個核心注解:
    * @CachePut:配置于函數上,能夠根據參數定義條件來進行緩存,它與@Cacheable不同的是,它每次都會真是調用函數,所以主要用于數據新增和修改操作上。它的參數與@Cacheable類似,具體功能可參考上面對@Cacheable參數的解析
    * @CacheEvict:配置于函數上,通常用在刪除方法上,用來從緩存中移除相應數據。除了同@Cacheable一樣的參數之外,它還有下面兩個參數:

  • allEntries:非必需,默認為false。當為true時,會移除所有數據
  • beforeInvocation:非必需,默認為false,會在調用方法之后移除數據。當為true時,會在調用方法之前移除數據。
  • 緩存配置

    在Spring Boot中通過@EnableCaching注解自動化配置合適的緩存管理器(CacheManager),Spring Boot根據下面的順序去偵測緩存提供者:

  • Generic
  • JCache (JSR-107)
  • EhCache 2.x
  • Hazelcast
  • Infinispan
  • Redis
  • Guava
  • Simple
  • 通常還是推薦去指定一個 緩存類型比較好,在系統配置文件配置:

    spring:cache:type: ehcache

    參考文章

    • Spring Boot中的緩存支持(一)注解配置與EhCache使用

    總結

    以上是生活随笔為你收集整理的学习Spring Boot:(二十一)使用 EhCache 实现数据缓存的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。