首页 > 其他 > 详细

Ehcache的配置(自学,有问题请指出)

时间:2014-04-02 10:41:22      阅读:497      评论:0      收藏:0      [点我收藏+]

最近在看Ehcache,刚开始看的时候无从下手,晚上介绍的文章有很多,但是我们实际用到的很少,本次用缓存关键是加快速度,对于那些非即时返回的数据的查询和存储进行缓存处理。本次是用于接口项目中,进行了监控和缓存。

ehcache缓存空间的建立主要是在spring配置中实现,配置文件在晚上有很多

spring下的配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?xml version="1.0" encoding="UTF-8"?>
    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的配置为

1
2
3
4
5
6
7
8
<?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"),其余的参数配置为:

1
2
3
4
5
6
7
8
9
10
        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方法,这里附上自己写的一个类的两个方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
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;
    }
}

  之后要用到的方法都可以在里面添加。暂时只写了部分。这个还要添加。

Ehcache的配置(自学,有问题请指出),布布扣,bubuko.com

Ehcache的配置(自学,有问题请指出)

原文:http://www.cnblogs.com/derek1208/p/3638136.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!