zoukankan      html  css  js  c++  java
  • Ehcache配置详解及CacheManager使用

     

     

    <?xml version="1.0" encoding="UTF-8"?> 
    <ehcache> 
    <!--timeToIdleSeconds 当缓存闲置n秒后销毁 --> 
    <!--timeToLiveSeconds 当缓存存活n秒后销毁 --> 
    <!-- 
    缓存配置 
           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:内存数量最大时是否清除。 
    -->



    EhcacheUtil工具类使用:

      1. public class EhcacheUtil {  
      2.   
      3.     private static final String path = "/ehcache.xml";  
      4.   
      5.     private URL url;  
      6.   
      7.     private CacheManager manager;  
      8.   
      9.     private static EhcacheUtil ehCache;  
      10.   
      11.     private EhcacheUtil(String path) {  
      12.         url = getClass().getResource(path);  
      13.         manager = CacheManager.create(url);  
      14.     }  
      15.   
      16.     public static EhcacheUtil getInstance() {  
      17.         if (ehCache== null) {  
      18.             ehCache= new EhcacheUtil(path);  
      19.         }  
      20.         return ehCache;  
      21.     }  
      22.   
      23.     public void put(String cacheName, String key, Object value) {  
      24.         Cache cache = manager.getCache(cacheName);  
      25.         Element element = new Element(key, value);  
      26.         cache.put(element);  
      27.     }  
      28.   
      29.     public Object get(String cacheName, String key) {  
      30.         Cache cache = manager.getCache(cacheName);  
      31.         Element element = cache.get(key);  
      32.         return element == null ? null : element.getObjectValue();  
      33.     }  
      34.   
      35.     public Cache get(String cacheName) {  
      36.         return manager.getCache(cacheName);  
      37.     }  
      38.   
      39.     public void remove(String cacheName, String key) {  
      40.         Cache cache = manager.getCache(cacheName);  
      41.         cache.remove(key);  
      42.     }  
      43.   
      44. }  
  • 相关阅读:
    【Java8新特性】你知道Java8为什么要引入Lambda表达式吗?
    你说你懂计算机网络,那这些你都知道吗
    程序员需要了解的硬核知识之控制硬件
    程序员需要了解的硬核知识之汇编语言(全)
    真的,Kafka 入门一篇文章就够了
    程序员需要了解的硬核知识之汇编语言(一)
    带你涨姿势的认识一下 Kafka 消费者
    程序员需要了解的硬核知识之操作系统和应用
    详解Kafka Producer
    程序员需要了解的硬核知识之操作系统入门
  • 原文地址:https://www.cnblogs.com/printN/p/6423161.html
Copyright © 2011-2022 走看看