yml:
spring:
cache:
type: ehcache
ehcache:
config: classpath:ehcache.xml
ehcache.xml
<?xml version="1.0" encoding="UTF-8"?>
<ehcache name="es" updateCheck="false" monitoring="autodetect" dynamicConfig="true">
<diskStore path="java.io.tmpdir"/>
<!--
name:缓存名称。
maxElementsInMemory:缓存最大个数。
eternal:对象是否永久有效,一但设置了,timeout将不起作用。
timeToIdleSeconds:设置对象在失效前的允许闲置时间(单位:秒)。
仅当eternal=false对象不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。
timeToLiveSeconds:设置对象在失效前允许存活时间(单位:秒)。最大时间介于创建时间和失效时间之间。
仅当eternal=false对象不是永久有效时使用,默认是0.,也就是对象存活时间无穷大。
overflowToDisk:当内存中对象数量达到maxElementsInMemory时,Ehcache将会对象写到磁盘中。
diskSpoolBufferSizeMB:这个参数设置DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区。
maxElementsOnDisk:硬盘最大缓存个数。
diskPersistent:是否缓存虚拟机重启期数据 Whether the disk store persists between restarts
of the Virtual Machine. The default value is false.
diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒。
memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。
默认策略是LRU(最近最少使用)。你可以设置为FIFO(先进先出)或是LFU(较少使用)。
clearOnFlush:内存数量最大时是否清除。
-->
<defaultCache maxEntriesLocalHeap="1000" eternal="false"
timeToIdleSeconds="3600" timeToLiveSeconds="3600" overflowToDisk="false">
</defaultCache>
<!-- 缓存4小时 -->
<cache name="getIntentionCityList" maxElementsInMemory="2000" eternal="false" statistics="true"
timeToIdleSeconds="18000" timeToLiveSeconds="14400" overflowToDisk="false" memoryStoreEvictionPolicy="LRU">
</cache>
<!-- 缓存4小时 -->
<cache name="getOrgData" maxElementsInMemory="2000" eternal="false" statistics="true"
timeToIdleSeconds="18000" timeToLiveSeconds="14400" overflowToDisk="false" memoryStoreEvictionPolicy="LRU">
</cache>
<!-- 缓存4小时 -->
<cache name="getIntentionCityPage" maxElementsInMemory="2000" eternal="false" statistics="true"
timeToIdleSeconds="18000" timeToLiveSeconds="14400" overflowToDisk="false" memoryStoreEvictionPolicy="LRU">
</cache>
</ehcache>
代码中使用
@Cacheable(cacheNames = "getIntentionCityPage", key = "#page", condition = "#name == null and #page == 1")
cacheNames 代表 cache 的名字 应于 ehcache.xml 中的配置对应,
key 代表 前端传入的参数,一个参数就是一份缓存,比如前端传 北京 ,那么就会产生一个叫北京的缓冲,之后前段再请求北京,返回缓存。需要注意这个key不能为空。
condition 代表 限制条件,(#name == null and #page == 1) 的意思是当前端传入的 name 参数为 null 且 page 参数为 1 时,创建缓存。