最近在看Ehcache,刚开始看的时候无从下手,晚上介绍的文章有很多,但是我们实际用到的很少,本次用缓存关键是加快速度,对于那些非即时返回的数据的查询和存储进行缓存处理。本次是用于接口项目中,进行了监控和缓存。
ehcache缓存空间的建立主要是在spring配置中实现,配置文件在晚上有很多
spring下的配置
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:cache="http://www.springframework.org/schema/cache" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-3.1.xsd"> <bean id="testServiceTarget" class="com.intime.test.TestServiceImpl"/> <!-- 缓存注解声明,使用注解缓存 --> <cache:annotation-driven cache-manager="cacheManager"></cache:annotation-driven> <!-- 指定ehcache.xml的位置 --> <bean id="cacheManagerFactory" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean" p:configLocation="classpath:/ehcache.xml" /> <!-- 声明缓存Manager --> <bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager" p:cacheManager-ref="cacheManagerFactory" /> </beans>
这里的缓存指定了ehcache.xml文件的位置(路径可自己定义):ehcache.xml的配置为
<?xml version="1.0" encoding="UTF-8"?> <ehcache> <diskStore path="java.io.tmpdir" /> <defaultCache maxElementsInMemory="50" eternal="false" timeToIdleSeconds="30" timeToLiveSeconds="120" overflowToDisk="true" /> <cache name="interface" maxElementsInMemory="5000" eternal="true" timeToIdleSeconds="500" timeToLiveSeconds="500" overflowToDisk="true" /> </ehcache>
其中这里配置了一个名为"interface"的缓存空间,这个空间的作用为存储临时数据,之后会将这个文件的数据存入数据库,这样做的原因是在监控接口时,不是将监控数据每次存入数据库,而是一段时间去查询一次缓存,将里面的数据放到数据库。因此这个缓存没有自动清理的功能,而是要手动管理(eternal="true"),其余的参数配置为:
name:Cache的唯一标识 · maxElementsInMemory:内存中最大缓存对象数。 · maxElementsOnDisk:磁盘中最大缓存对象数,若是0表示无穷大。 · eternal:Element是否永久有效,一但设置了,timeout将不起作用。 · overflowToDisk:配置此属性,当内存中Element数量达到maxElementsInMemory时,Ehcache将会Element写到磁盘中。 · timeToIdleSeconds:设置Element在失效前的允许闲置时间。仅当element不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。 · timeToLiveSeconds:设置Element在失效前允许存活时间。最大时间介于创建时间和失效时间之间。仅当element不是永久有效时使用,默认是0.,也就是element存活时间无穷大。 · diskPersistent:是否缓存虚拟机重启期数据。 · diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒。 · diskSpoolBufferSizeMB:这个参数设置DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区。
在以后要用到缓存的时候随时能添加新的空间加以控制。
java类的写法:这里主要介绍存入缓存和取出缓存数据,本人在网上找了好久也没找到一个完整的写入写出过程,一般写入可以用注解或者调用cache的put方法,但是cache没有get方法,这里附上自己写的一个类的两个方法:
package ××××××××××××××××××; import java.util.ArrayList; import java.util.List; import net.sf.ehcache.Cache; import net.sf.ehcache.CacheManager; import net.sf.ehcache.Element; /** * * <b>类名称:</b>WriteCache.<br/> * <b>类描述:</b><br/> * <b>创建者:Zhoupz</b> <br/> * <b>创建时间:</b>2014-3-31 上午10:29:42<br/> * <pre> * <b>修订记录:</b> * 版本 日期 修订人 描述 * ------------------------------------------------------------- * 1.0 2014-3-31 Zhoupz 写入缓存 * * </pre> */ public class EhCache { /** * * sqlCache:。<br/> * (存Cache)<br/> * @since 1.0 * @param data */ public void setCache(String cacheName, String key, Object value) { CacheManager cacheManager = CacheManager.create(); Cache cache = cacheManager.getCache(cacheName); Element element = new Element(key, value); cache.put(element); } /** * * getCache:。<br/> * (取Cache)<br/> * @since 1.0 */ public Object getCache(String cacheName,String key){ CacheManager cacheManager = CacheManager.create(); Cache cache = cacheManager.getCache(cacheName); List<String> list = cache.getKeys(); Object object = null; for (int i = 0; i < list.size(); i++) { //遍历缓存中所有数据 String s = cache.get(list.get(i)).getKey().toString(); if(s.equals(key)){ object = cache.get(list.get(i)).getValue(); } } return object; } /** * * getCache:。<br/> * (调取缓存数据并清除调取数据---用于非自动清空的缓存)<br/> * @since 1.0 * @param cacheNames * @return */ public List<Object> getCache(String cacheName){ List<Object> result = new ArrayList<Object>(); CacheManager cacheManager = CacheManager.create(); Cache cache = cacheManager.getCache(cacheName); List<String> list = cache.getKeys(); for (int i = 0; i < list.size(); i++) { result.add(cache.get(list.get(i)).getValue()); cache.remove(list.get(i)); } return result; } }
之后要用到的方法都可以在里面添加。暂时只写了部分。这个还要添加。