Spring整合Ehcache

1488966428

前言Spring整合其他的框架一般思路就是用Spring的Bean来管理,就行Spring与hibernate的sessionFactory一样

我使用的IDE和工具是idea+meavn

1.在pom.xml添加ehcache依赖 <dependency> <groupId>net.sf.ehcache</groupId> <artifactId>ehcache</artifactId> <version>2.8.2</version> </dependency>
2.Ehcache的配置文件ehcache-setting.xml

<?xml version=”1.0” encoding=”UTF-8”?>

<ehcache>

&lt;diskStore path="java.io.tmpdir"/&gt;

<!-- 设定缓存的默认数据过期策略 -->
<defaultCache  maxElementsInMemory="10000" eternal="false" overflowToDisk="true" timeToIdleSeconds="10" timeToLiveSeconds="20" diskPersistent="false" diskExpiryThreadIntervalSeconds="120"/>

<cache name="cacheTest" maxElementsInMemory="1000" eternal="false" overflowToDisk="true" timeToIdleSeconds="10" timeToLiveSeconds="20"/>

</ehcache>
下面是cache元素的属性
name:缓存名称

maxElementsInMemory:内存中最大缓存对象数

maxElementsOnDisk:硬盘中最大缓存对象数,若是0表示无穷大

eternal:true表示对象永不过期,此时会忽略timeToIdleSeconds和timeToLiveSeconds属性,默认为false

overflowToDisk:true表示当内存缓存的对象数目达到了

maxElementsInMemory界限后,会把溢出的对象写到硬盘缓存中。注意:如果缓存的对象要写入到硬盘中的话,则该对象必须实现了Serializable接口才行。

diskSpoolBufferSizeMB:磁盘缓存区大小,默认为30MB。每个Cache都应该有自己的一个缓存区。

diskPersistent:是否缓存虚拟机重启期数据,是否持久化磁盘缓存,当这个属性的值为true时,系统在初始化时会在磁盘中查找文件名为cache名称,后缀名为index的文件,这个文件中存放了已经持久化在磁盘中的cache的index,找到后会把cache加载到内存,要想把cache真正持久化到磁盘,写程序时注意执行net.sf.ehcache.Cache.put(Element element)后要调用flush()方法。

diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认为120秒

timeToIdleSeconds: 设定允许对象处于空闲状态的最长时间,以秒为单位。当对象自从最近一次被访问后,如果处于空闲状态的时间超过了timeToIdleSeconds属性值,这个对象就会过期,EHCache将把它从缓存中清空。只有当eternal属性为false,该属性才有效。如果该属性值为0,则表示对象可以无限期地处于空闲状态

timeToLiveSeconds:设定对象允许存在于缓存中的最长时间,以秒为单位。当对象自从被存放到缓存中后,如果处于缓存中的时间超过了 timeToLiveSeconds属性值,这个对象就会过期,EHCache将把它从缓存中清除。只有当eternal属性为false,该属性才有效。如果该属性值为0,则表示对象可以无限期地存在于缓存中。timeToLiveSeconds必须大于timeToIdleSeconds属性,才有意义

memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。可选策略有:LRU(最近最少使用,默认策略)、FIFO(先进先出)、LFU(最少访问次数)。
3.在applicationContext.xml添配置Bean

<!--启用缓存注解功能-->

<cache:annotation-driven cache-manager=”cacheManager” />

<bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager">
    <property name="cacheManager" ref="ehcache"></property>
</bean>

<bean id="ehcache" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
    <property name="configLocation" value="classpath:ehcache-setting.xml"></property>
</bean>
<!--ehche end-->

别忘了在根标签添加xmlns:cache=”http://www.springframework.org/schema/cache

4.编写Service
package com.ehcache.service;

import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;

/**

  • Created by Ape
    */
    @Service
    public class EhcacheService {

    /**

    • 这里注解中value=cacheTest与ehcache-setting.xml中的cache名称属性值一致。
    • @param key
    • @return
      */
      @Cacheable(value = “cacheTest”, key = “‘key-‘ + #key”)
      public String get(String key){
      return String.valueOf(System.currentTimeMillis());
      }

}
5.编写测试方法
@Autowired
private EhcacheService ehcacheService;
@Test
public void test() throws InterruptedException {
System.out.println(“第一次调用->” + ehcacheService.get(“k”));
Thread.sleep(2000);
System.out.println(“2秒后调用->” + ehcacheService.get(“k”));
Thread.sleep(9900);
System.out.println(“9.9秒后调用->” + ehcacheService.get(“k”));
Thread.sleep(10001);
System.out.println(“10.001秒后调用->” + ehcacheService.get(“k”));
}
配置文件设定10秒缓存,运行结果会看到键值为k的10秒内的获取结果一样

这样就成功整合了Ehcache