一、需要导入的jar包
1.ehcache.jar
2.ehcache-spring-annotations-1.2.0.jar
3.guava-r09.jar
4.slf4j-api-1.6.6.jar
二、配置文件
1.spring配置文件
beans<
xmlns:cache="http://www.springframework.org/schema/cache"
xsi:schemaLocation="http://www.springframework.org/schema/cache
http://www.springframework.org/schema/cache/spring-cache-3.2.xsd"
>
<!--启用缓存注解功能-->
<cache:annotation-driven cache-manager="cacheManager" />
<!-- Spring提供的基于的Ehcache实现的缓存管理器 -->
<bean id="cacheManagerFactory" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
<property name="configLocation" value="classpath:ehcache.xml" />
</bean>
<bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager">
<property name="cacheManager" ref="cacheManagerFactory" />
</bean>
</beans>
2.ehcache.xml
<?xml version="1.0" encoding="UTF-8"?>
<ehcache>
<!--当内存缓存中对象数量超过maxElementsInMemory时,将缓存对象写到磁盘缓存中。用来配置磁盘缓存使用的物理路径,Ehcache磁盘缓存使用的文件后缀名是data和index-->
<diskStore path="java.io.tmpdir"/>
<defaultCache
maxElementsInMemory="1000"
eternal="false"
<!--缓存数据在失效前的允许闲置时间(单位:秒),仅当eternal=
false
时使用,默认值是
0
表示可闲置时间无穷大,此为可选属性.即访问这个cache中元素的最大间隔时间,若超过这个时间没有访问此Cache中的某个元素,那么此元素将被从Cache中清除
-->
timeToIdleSeconds="120"
<!--缓存数据在失效前的允许存活时间(单位:秒),仅当eternal=
false
时使用,默认值是
0
表示可存活时间无穷大,此为可选属性。即Cache中的某元素从创建到清楚的生存时间,也就是说从创建开始计时,当超过这个时间时,此元素将从Cache中清除
-->
timeToLiveSeconds="120"
overflowToDisk="false"
<!--磁盘缓存的清理线程运行间隔,默认是
120
秒
-->
diskExpiryThreadIntervalSeconds="120"
<!--内存存储与释放策略,即达到maxElementsInMemory限制时,Ehcache会根据指定策略清理内存,
共有三种策略,分别为LRU(最近最少使用)、LFU(最常用的)、FIFO(先进先出)-->
memoryStoreEvictionPolicy="LRU"
/>
<cache
<!--缓存名称,cache的唯一标识。ehcache会把这个cache放到hashmap里-->
name="myCache"
<!--磁盘缓存中最多可以存放的元素数量,0表示无穷大-->
maxElementsOnDisk="20000"
<!--内存缓存中最多可以存放的元素数量,若放入Cache中的元素超过这个数值,则有以下两种情况:(1)若overflowToDisk=
true
,则会将Cache中多出的元素放入磁盘文件中 (2)
-->若overflowToDisk=
false
,则根据memoryStoreEvictionPolicy策略替换Cache中原有的元素
maxElementsInMemory="2000"
<!--缓存中对象是否永久有效,也就是是否永存内存,true
时将忽略timeToIdleSeconds和timeToLiveSeconds
-->
eternal="false"
<!--内存不足时,是否启用磁盘缓存(即内存中对象数量达到maxElementsInMemory时,Ehcache会将对象写到磁盘中)会根据标签中path值查找对应的属性值,写入磁盘的文件会放在path文件夹下,文件的名称是cache的名称,后缀名是data-->
overflowToDisk="true"
<!--是否持久化磁盘缓存,当这个属性的值为
true
时,系统在初始化时会在磁盘中查找文件名为cache名称,后缀名为index的文件,
这个文件中存放了已经持久化在磁盘中的cache的index,找到后会把cache加载到内存,要想把cache真正持久化到磁盘,写程序时注意执行net.sf.ehcache.Cache.put(Element element)后要调用flush()方法-->
diskPersistent="true"
/>
<cache
name="default"
maxElementsOnDisk="20000"
maxElementsInMemory="2000"
eternal="false"
overflowToDisk="true"
diskPersistent="true"/>
</ehcache>
三、cache一般用在与数据库交互的地方(可用在dao层和service层中)
@Cacheable(value="default",key="#equipbranch")
public List<Object> getEquipBranch2(String parentId){
return indexDao.equipBranch2(parentId);
}
注:
(1)@Cacheable缓存原理:在取值时在方法调用前查看缓存中是否有目标值,如果缓存中有值得话就不再执行方法,直接从缓存中取值。
(2)@CacheEvict缓存中需要更新:这个注解的意思是删掉缓存里的某个值,从而达到更新缓存的效果,做到缓存与数据库同步。
(3)@CachePut既保证方法被调用,又把结果缓存。
(4)注解里面属性解释:
@Cacheable和@CachePut里的属性是相同的。
a)value:缓存的名称,在spring配置文件中定义,必须指定至少一个
b)key:缓存的key,(缓存是键值对儿)可以为空,如果指定要按照 SpEL 表达式编写,如果不指定,则缺省按照方法的所有参数进行组合
c)condition:缓存的条件,可以为空,使用SpEL 编写,返回 true 或者 false,只有为 true 才进行缓存
@CacheEvict除了上面的三个属性外,还有和删除相关的两个属性
d)allEntries:是否清空所有缓存内容,缺省为 false,如果指定为 true,则方法调用后将立即清空所有缓存
e)beforeInvocation:是否在方法执行前就清空,缺省为 false,如果指定为 true,则在*方法还没有执行的时候就清空缓存,缺省情况下为false,这样如果方法执行抛出异常,则不会清空缓存