ehcache
来源:互联网 发布:淘宝店需要营业执照吗 编辑:程序博客网 时间:2024/06/05 10:35
1.ehcache.xml配置文件详解
<ehcache>
<!--磁盘存储配置:用来指定缓存在磁盘上的存储位置。
<diskStorepath = "c:/cache/" />
<!--指定CacheManagerEventListenerFactory,这个对象在缓存添加的时候会得到相应的通知。
属性:
*class :CacheManagerEventListenerFactory的一个实现类。
*properties :CacheManagerEventListenerFactory的属性值,以逗号(,)分割多个属性。
如果没有实现类被指定,则系统不创建CacheManager的监听器,没有默认值-->
<cacheManagerEventListenerFactoryclass="" properties="" />
<!--在进行分布式缓存的应用时需要指定CacheManagerPeerProviderFactory,用来生成CacheManagerPeerProvider的实例,以便和集群中的其他CacheManager通信。
CacheManagerPeerProvider的属性:
*class :CacheManagerPeerProviderFactory的一个实现类。
*properties :CacheManagerPeerProviderFactory的属性值,以逗号(,)分割多个属性。
Ehcache内建了2种基于RMI分布系统的通信策略:
*automatic :使用多播组。在一个节点加入或者推出集群的时候自动感应。
*manual :硬编码方式
-->
<cacheManagerPeerListenerFactoryclass="" properties="" />
<!--默认缓存配置,以下属性是必须的:
name :cache的标识符,在一个CacheManager中必须唯一。
maxElementsInMemory :在内存中缓存的element的最大数目。
maxElementsOnDisk :在磁盘上缓存的element的最大数目。
eternal :设定缓存的elements是否有有效期。如果为true,timeouts属性被忽略。
overflowToDisk :设定当内存缓存溢出的时候是否将过期的element缓存到磁盘上。
以下属性是可选的:
timeToIdleSeconds :缓存element在过期前的空闲时间。
timeToLiveSeconds :缓存element的有效生命期。
diskPersistent :在VM重启的时候是否持久化磁盘缓存,默认是false。
diskExpiryThreadIntervalSeconds :磁盘缓存的清理线程运行间隔,默认是120秒.
memoryStoreEvictionPolicy :当内存缓存达到最大,有新的element加入的时候,
移除缓存中element的策略。默认是LRU,可选的有LFU和FIFO
缓存子元素:
cacheEventListenerFactory:注册相应的的缓存监听类,用于处理缓存事件,如put,remove,update,和expire
bootstrapCacheLoaderFactory:指定相应的BootstrapCacheLoader,用于在初始化缓存,以及自动设置。
-->
<defaultCache
maxElementsInMemory="10000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
overflowToDisk="true"
maxElementsOnDisk="1000000"
diskPersistent="false"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU"
/>
<!--cache配置同defaultCache -->
<cachename="test"
maxElementsInMemory="100"
eternal="false"
timeToIdleSeconds="100"
timeToLiveSeconds="100"
overflowToDisk="false"
/>
</ehcache>
2.ehcache 包可用方法介绍:
创建CacheManager 的方法:
方法一:
CacheManager manager = new CacheManager();
方法二:
CacheManager manager = new CacheManager("src/config/ehcache.xml");
方法三:
URL url = getClass().getResource("/anotherconfigurationname.xml");
CacheManager manager = new CacheManager(url);
方法四:
InputStream fis = new FileInputStream(newFile("src/config/ehcache.xml").getAbsolutePath());
try {
CacheManager manager = new CacheManager(fis);
} finally {
fis.close();
}
获取cacheNames 列表:
方法一:
CacheManager.create();
String[] cacheNames = CacheManager.getInstance().getCacheNames();
方法二:
CacheManager manager = new CacheManager();
String[] cacheNames = manager.getCacheNames();
方法三:
CacheManager manager1 = new CacheManager("src/config/ehcache1.xml");
CacheManager manager2 = new CacheManager("src/config/ehcache2.xml");
String[] cacheNamesForManager1 = manager1.getCacheNames();
String[] cacheNamesForManager2 = manager2.getCacheNames();
添加和删除缓存元素:
设置一个名为testCache 的新cache,属性为默认:
CacheManager singletonManager = CacheManager.create();
singletonManager.addCache("testCache");
Cache test = singletonManager.getCache("testCache");
设置一个名为testCache 的新cache,并定义其属性:
CacheManager singletonManager = CacheManager.create();
Cache memoryOnlyCache = new Cache("testCache", 5000, false, false, 5,2);
singletonManager.addCache(memoryOnlyCache);
Cache test = singletonManager.getCache("testCache");
Cache 属性说明:
构造函数:
public Cache(String name,
intmaxElementsInMemory,
booleanoverflowToDisk,
boolean eternal,
longtimeToLiveSeconds,
longtimeToIdleSeconds)
参数说明:
name :元素名字。
maxElementsInMemory :设定内存中创建对象的最大值。
overflowToDisk :设置当内存中缓存达到 maxInMemory 限制时元素是否可写到磁盘上。
eternal :设置元素是否永久驻留。
timeToIdleSeconds :设置某个元素消亡前的停顿时间。也就是在一个元素消亡之前,两次访问时间的最大时间间隔值。只能在元素不是永久驻留时有效。
timeToLiveSeconds :设置某个元素消亡前的生存时间。也就是一个元素从构建到消亡的最大时间间隔值。只能在元素不是永久驻留时有效。
删除缓存元素:
CacheManager singletonManager = CacheManager.create();
singletonManager.removeCache("testCache");
关闭缓存管理器 CacheManager
CacheManager.getInstance().shutdown();
对于缓存对象的操作:
放入一个简单的对象到缓存元素;
Cache cache = manager.getCache("testCache");
Element element = new Element("key1", "value1");
cache.put(element);
得到一个序列化后的对象属性值;
Cache cache = manager.getCache("testCache");
Element element = cache.get("key1");
Serializable value = element.getValue();
得到一个没有序列化后的对象属性值;
Cache cache = manager.getCache("testCache");
Element element = cache.get("key1");
Object value = element.getObjectValue();
删除一个对象从元素;
Cache cache = manager.getCache("testCache");
Element element = new Element("key1", "value1");
cache.remove("key1");
对于永固性磁盘存储,立即存储到磁盘:
Cache cache = manager.getCache("testCache");
cache.flush();
获得缓存大小:
得到缓存的对象数量;
Cache cache = manager.getCache("testCache");
int elementsInMemory = cache.getSize();
得到缓存对象占用内存的数量
Cache cache = manager.getCache("testCache");
long elementsInMemory = cache.getMemoryStoreSize();
得到缓存对对象占用磁盘的数量
Cache cache = manager.getCache("testCache");
long elementsInMemory = cache.getDiskStoreSize();
关于缓存的读取和丢失的记录:
得到缓存读取的命中次数;
Cache cache = manager.getCache("testCache");
int hits = cache.getHitCount();
得到内存中缓存读取的命中次数;
Cache cache = manager.getCache("testCache");
int hits = cache.getMemoryStoreHitCount();
得到磁盘中缓存读取的命中次数;
Cache cache = manager.getCache("testCache");
int hits = cache.getDiskStoreCount();
得到缓存读取的丢失次数;
Cache cache = manager.getCache("testCache");
int hits = cache.getMissCountNotFound();
得到缓存读取的已经被销毁的对象丢失次数;
Cache cache = manager.getCache("testCache");
int hits = cache.getMissCountExpired();
- Ehcache
- Ehcache
- ehcache
- ehcache
- EHCache
- ehCache
- ehcache
- ehcache
- ehcache
- ehcache
- ehcache
- ehcache
- EhCache
- Ehcache
- ehcache
- Ehcache
- ehcache
- EHCache
- Centos6.6 yum源更新
- Recognizer API
- The processing instruction target matching "[xX][mM][lL]" is not allowed.
- #学志#[jsp&&php]获取客户机mac地址
- Trie字典树模板
- ehcache
- sql server复制表结构语法
- HTML学习笔记-制作表格
- 对噪声有较好鲁棒性的相位解包裹算法
- KMP算法next数组解析
- Python学习笔记(十)—— Set
- python基础之元组、列表、集合
- 如何高效、快捷、投入少地学习新的知识
- ReactiveCocoa入门教程:第一部分