SpringBoot2 整合Ehcache組件,輕量級快取管理
- 2020 年 8 月 9 日
- 筆記
- Ehcache, Spring.Boot.Cloud, springboot, 快取
本文源碼:GitHub·點這裡 || GitEE·點這裡
一、Ehcache快取簡介
1、基礎簡介
EhCache是一個純Java的進程內快取框架,具有快速、上手簡單等特點,是Hibernate中默認的快取提供方。
2、Hibernate快取
Hibernate三級快取機制簡介:
一級快取:基於Session級別分配一塊快取空間,快取訪問的對象資訊。Session關閉後會自動清除快取。
二級快取:是SessionFactory對象快取,可以被創建出的多個 Session 對象共享,二級快取默認是關閉的,如果要使用需要手動開啟,並且依賴EhCache組件。
三級快取:查詢快取,配置開啟該快取的情況下,重複使用一個sql查詢某個範圍內的數據,會進行快取。
3、EhCache快取特點
- 快速,簡單,並且提供多種快取策略;
- 快取數據有兩級:記憶體和磁碟,無需擔心容量問題;
- 快取數據會在虛擬機重啟的過程中寫入磁碟;
- 可以通過RMI、可插入API等方式進行分散式快取;
- 具有快取和快取管理器的偵聽介面;
- 支援多快取管理器實例,以及一個實例的多個快取區域;
- 提供Hibernate的快取實現;
4、對比Redis快取
Ehcache:直接在Jvm虛擬機中快取,速度快,效率高,不適合處理大規模快取數據,在分散式環境下,快取數據共享操作複雜;
Redis:作為獨立的快取中間件,在分散式快取系統中非常好用,快取數據共享,有效支撐大量數據快取,支援哨兵模式,或者集群模式的高可用成熟方案;
二、集成SpringBoot框架
1、核心依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
<groupId>net.sf.ehcache</groupId>
<artifactId>ehcache</artifactId>
</dependency>
2、載入配置
基礎配置
spring:
cache:
ehcache:
config: classpath:ehcache.xml
啟動類註解
@EnableCaching
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class,args) ;
}
}
3、配置詳解
<ehcache xmlns:xsi="//www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">
<!-- 作業系統快取的臨時目錄,記憶體滿後寫入該目錄 -->
<diskStore path="java.io.tmpdir"/>
<defaultCache
maxElementsInMemory="1000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
maxElementsOnDisk="10000000"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
<persistence strategy="localTempSwap"/>
</defaultCache>
<cache name="userEntity"
maxElementsInMemory="1000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
maxElementsOnDisk="10000000"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
<persistence strategy="localTempSwap"/>
</cache>
</ehcache>
配置參數說明
maxElementsOnDisk:磁碟快取中最多可以存放的元素數量;
eternal:快取中對象是否永久有效;
timeToIdleSeconds:當eternal=false時使用,快取數據有效期(單位:秒),時間段內沒有訪問該元素,將被清除;
timeToLiveSeconds:快取數據的存活時間;
maxElementsInMemory:記憶體中最多可以存放的元素數量,overflowToDisk=true,則會將Cache中多出的元素放入磁碟文件中,若overflowToDisk=false,則根據memoryStoreEvictionPolicy策略替換Cache中原有的元素;
diskExpiryThreadIntervalSeconds:磁碟快取的清理執行緒運行間隔;
memoryStoreEvictionPolicy:快取釋放策略,LRU會優先清理最少使用的快取;
localTempSwap:持久化策略,當堆記憶體或者非堆記憶體裡面的元素已經滿了的時候,將其中的元素臨時的存放在磁碟上,重啟後就會消失;
三、註解用法
@Service
public class CacheService {
private static final Logger LOGGER = LoggerFactory.getLogger(CacheService.class);
@Resource
private UserMapper userMapper ;
@Cacheable(value="userEntity") // 在快取有效期內,首次查詢才訪問資料庫
public UserEntity getById (Integer id){
// 通過日誌,標識方法是否執行
LOGGER.info("getById..."+id);
return userMapper.selectById(id) ;
}
@CacheEvict(value="userEntity",key = "#id") //該ID數據更新,清空該ID快取
public void updateUser(Integer id) {
UserEntity user = new UserEntity() ;
user.setId(id);
user.setUserName("myCache");
userMapper.updateById(user);
}
}
@Cacheable:註解標記在一個方法上,也可以標記在一個類上,標記在一個方法上表示該方法支援快取,該方法被調用後將其返回值快取起來,下次同樣的請求參數執行該方法時可以直接從快取中獲取結果,而不需要再次執行該方法。
@CacheEvict:註解標記在需要清除快取元素的方法或類上的,當標記在一個類上時表示其中所有的方法的執行都會觸發快取的清除操作,並且可以按照指定屬性清除。
四、源程式碼地址
GitHub·地址
//github.com/cicadasmile/middle-ware-parent
GitEE·地址
//gitee.com/cicadasmile/middle-ware-parent
推薦閱讀:SpringBoot進階系列