- 浏览: 486772 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
fanxp:
很好,学习了!
mysql导入数据load data infile用法 -
maomao15:
...
(转) Class.getResource与ClassLoader.getResource()区别 -
贾懂凯:
有maven的配置吗?
Spring MVC整合Velocity的例子 -
kevinhrw:
一个好办法不知道使用"mvc:resources&q ...
Spring3.0 做rest时候拦截js、图片 -
love_miaohong:
这样子设置没作用啊, window7系统下用这个方式不行
MongoDB在windows操作系统cmd下乱码
EHCache使用简介
EHCache 是一个纯java的,在Hibernate2.1充当可插入的的在进程中的缓存,它具有以下缓存,最小的依赖性,全面的文特性:快速,简单,丰富的文档和测试用例。
官方网站 http://ehcache.sourceforge.net/
--------------------------
----------使用简介------------
--------------------------
ehcache-1.2 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();
ehcache-1.2 管理器各种建立的方法:
方法一:
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(new File("src/config/ehcache.xml").getAbsolutePath());
try {
CacheManager manager = new CacheManager(fis);
} finally {
fis.close();
}
添加和删除缓存元素
设置一个名为test 的新cache,test属性为默认
CacheManager singletonManager = CacheManager.create();
singletonManager.addCache("testCache");
Cache test = singletonManager.getCache("testCache");
设置一个名为test 的新cache,并定义其属性
CacheManager singletonManager = CacheManager.create();
Cache memoryOnlyCache = new Cache("testCache", 5000, false, false, 5, 2);
manager.addCache(memoryOnlyCache);
Cache test = singletonManager.getCache("testCache");
Cache 属性说明:
构造函数:
public Cache(java.lang.String name,
int maxElementsInMemory,
boolean overflowToDisk,
boolean eternal,
long timeToLiveSeconds,
long timeToIdleSeconds)
参数说明:
name - 元素名字。
maxElementsInMemory - 设定内存中创建对象的最大值。
overflowToDisk - 设置当内存中缓存达到 maxInMemory 限制时元素是否可写到磁盘
上。
eternal - 设置元素(译注:内存中对象)是否永久驻留。如果是,将忽略超
时限制且元素永不消亡。
timeToIdleSeconds - 设置某个元素消亡前的停顿时间。
也就是在一个元素消亡之前,两次访问时间的最大时间间隔值。
这只能在元素不是永久驻留时有效(译注:如果对象永恒不灭,则
设置该属性也无用)。
如果该值是 0 就意味着元素可以停顿无穷长的时间。
timeToLiveSeconds - 为元素设置消亡前的生存时间。
也就是一个元素从构建到消亡的最大时间间隔值。
这只能在元素不是永久驻留时有效。
删除缓存元素:
CacheManager singletonManager = CacheManager.create();
singletonManager.removeCache("test");
关闭缓存管理器 CacheManager
CacheManager.getInstance().shutdown();
对于缓存对象的操作:
放入一个简单的对象到缓存元素;
Cache cache = manager.getCache("sampleCache1");
Element element = new Element("key1", "value1");
cache.put(element);
得到一个序列化后的对象属性值;
Cache cache = manager.getCache("sampleCache1");
Element element = cache.get("key1");
Serializable value = element.getValue();
得到一个没有序列化后的对象属性值;
Cache cache = manager.getCache("sampleCache1");
Element element = cache.get("key1");
Object value = element.getObjectValue();
删除一个对象从元素;
Cache cache = manager.getCache("sampleCache1");
Element element = new Element("key1", "value1"
cache.remove("key1");
对于永固性磁盘存储,立即存储到磁盘:
Cache cache = manager.getCache("sampleCache1");
cache.flush();
获得缓存大小:
得到缓存的对象数量;
Cache cache = manager.getCache("sampleCache1");
int elementsInMemory = cache.getSize();
得到缓存对象占用内存的数量
Cache cache = manager.getCache("sampleCache1");
long elementsInMemory = cache.getMemoryStoreSize();
得到缓存对对象占用磁盘的数量
Cache cache = manager.getCache("sampleCache1");
long elementsInMemory = cache.getDiskStoreSize();
关于缓存的读取和丢失的记录
得到缓存读取的命中次数;
Cache cache = manager.getCache("sampleCache1");
int hits = cache.getHitCount();
得到内存中缓存读取的命中次数;
Cache cache = manager.getCache("sampleCache1");
int hits = cache.getMemoryStoreHitCount();
得到磁盘中缓存读取的命中次数;
Cache cache = manager.getCache("sampleCache1");
int hits = cache.getDiskStoreCount();
得到缓存读取的丢失次数;
Cache cache = manager.getCache("sampleCache1");
int hits = cache.getMissCountNotFound();
得到缓存读取的已经被销毁的对象丢失次数;
Cache cache = manager.getCache("sampleCache1");
int hits = cache.getMissCountExpired();
--------------------------
----------简单例子------------
--------------------------
实战:
XML文件格式:
<ehcache>
<diskStore path="java.io.tmpdir"/>
<defaultCache
maxElementsInMemory="10000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
overflowToDisk="true"
diskPersistent="false"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU"
/>
<cache name="cache1"
maxElementsInMemory="10000"
eternal="false"
overflowToDisk="true"
timeToIdleSeconds="2"
timeToLiveSeconds="3"
memoryStoreEvictionPolicy="LFU"
/>
</ehcache>
发表评论
-
ThreadPoolExecutor线程池参数设置技巧
2017-12-19 13:06 1360一、ThreadPoolExecutor的重要参数 ... -
Java中如何设置使用代理IP发送网络请求
2016-04-20 10:45 2074Java中有两种方法可以实现用代理IP连接网络。 方式一, ... -
JDK并发工具包CompletionService和ExecutorCompletionService的好处和使用场景
2016-04-13 14:06 1851《Java并发编程实践》一书6.3.5节Complet ... -
HttpClient容易忽视的细节——连接关闭
2015-09-06 14:09 1163Java代码 HttpCl ... -
深入浅出 消息队列 ActiveMQ
2015-08-21 10:39 1409一、 概述与介绍 ActiveMQ 是Apach ... -
Java 代码 调用浏览器 打开url (支持多个操作系统)
2014-03-31 14:58 1943package com.ab.galaxy.test.mai ... -
Ant 实战
2013-10-22 10:13 859Ant是什么? Ant是一个构建工具,它可以帮助我们 ... -
30天轻松掌握JavaWeb
2013-10-22 10:07 1164Java Web,是用Java技术来解决相关we ... -
在线文档 doc.gotomao.com
2013-06-24 23:00 71http://doc.gotomao.com/ -
(转) Class.getResource与ClassLoader.getResource()区别
2013-06-04 22:14 1711class.getResource(String res)的 ... -
(转)PV,V,UV的概念,采集数据
2012-10-23 13:08 1220GUID IP+ 随机数 ... -
【转】Atlassian Confluence安装以及如何更改数据库
2012-08-22 16:14 3019Confluence是一个国外的一款商业wiki软 ... -
gzip解压
2011-07-26 12:06 707GZIPInputStream GIS=new GZIPInp ... -
MongoDB在windows操作系统cmd下乱码
2011-05-03 14:13 2932原因:由于mongodb后台的字符编码都是utf-8的, ... -
设计自己的Annotation
2011-04-05 11:37 778Annotation在java的世界正铺天盖地展开 ... -
jstl 的 <fn:> 标签应用(转)
2011-01-09 19:08 1051在jsp页面上经常遇到得到集合长度、字符长度、字符 ... -
mencached入门 pdf
2011-01-03 20:19 973见附件 -
让FCKeditor自动换行
2010-12-21 10:03 1596使用FCKEditor进行文本编辑时,当输入满一行时, ... -
Apache POI组件操作Excel,制作报表(二) (转)
2010-12-19 20:26 2037现在来看看Excel的基本设置问题,以2007为例,先从工作 ... -
Apache POI组件操作Excel,制作报表(一) (转)
2010-12-19 19:32 1204Apache的POI组件是Java操作Microsoft ...
相关推荐
本文旨在深入探讨Ehcache的关键特性和实现原理,以便于开发者能够更好地理解和应用这一优秀的缓存技术。 #### 二、特性概览 ##### 1. 快速轻量 - **速度**:经过多次测试证明,Ehcache是最快的Java缓存之一。 - *...
为了使上述配置生效,还需要在项目的构建文件(如Maven的pom.xml)中添加ehcache的相关依赖: ```xml <!-- Maven依赖 --> <groupId>net.sf.ehcache</groupId> <artifactId>ehcache-core <version>2.4.8 ``` #...
`ehcache reference&guide.pdf` 文件很可能是EhCache的官方参考指南或用户手册,通常会详细介绍如何配置EhCache,设置缓存策略,以及如何在项目中集成和使用EhCache。这份文档会涵盖以下内容: - EhCache的基本概念...
在Ehcache的使用中,我们需要了解以下几个关键API: 1. `CacheManager`: 这是Ehcache的核心管理类,负责创建、管理和销毁缓存区。你可以通过`CacheManager.create()`静态方法获取或创建一个新的`CacheManager`实例...
在实际开发中,Ehcache的使用通常分为以下步骤: 1. **引入依赖**:在Maven或Gradle的配置文件中添加Ehcache的依赖库。 2. **配置缓存**:创建XML配置文件,定义缓存的大小、过期策略等属性。 3. **创建缓存管理...
EHCache是一种广泛使用的开源Java缓存框架,它支持多种缓存策略,适用于各种应用场景。 在数据持久层,特别是与Hibernate结合使用时,缓存扮演着关键角色。Hibernate的缓存主要分为一级缓存和二级缓存。一级缓存,...
在Maven项目中使用Ehcache,首先需要在`pom.xml`文件中添加Ehcache的依赖。通常,我们会引用最新稳定版本的Ehcache库,如下所示: ```xml <groupId>org.ehcache <artifactId>ehcache <version>3.x.y</version> ...
- 如果可能,考虑使用Ehcache的分布式功能以提升大规模应用的性能。 总的来说,Ehcache-1.2.2.jar为Java开发者提供了一种高效、灵活的缓存解决方案,通过合理使用,可以显著提升应用的响应速度和整体性能。同时,...
#### 一、EHCache简介 EHCache 是一款开源的 Java 缓存框架,用于在应用程序中实现缓存功能。它提供了高性能、内存和磁盘缓存支持,使得开发者能够轻松地管理和控制数据的缓存策略。EHCache 可以在开发模式下作为...
Ehcache的特点包括: - **多级缓存支持**:支持内存和磁盘两种存储方式,可以根据不同的场景选择合适的缓存级别。 - **灵活的缓存淘汰策略**:提供了LRU(Least Recently Used)、LFU(Least Frequently Used)以及...
Ehcache的主要特点包括: 1. 高性能:Ehcache使用内存作为主要存储,访问速度快。 2. 可配置性:可以设置缓存策略,如大小限制、过期时间等。 3. 分布式:通过Terracotta服务器,Ehcache支持多节点的分布式缓存。 ...
- **文档范围**:覆盖了Ehcache的基础概念、配置方法、应用场景,特别是页面级别的缓存处理以及在分布式集群环境下的配置。 - **读者对象**:面向所有希望学习或进一步提高Ehcache使用技巧的技术人员。 #### 二、...
【SpringBoot中使用Ehcache的详细教程】 EhCache是一个高效的Java进程内缓存框架,因其快速、轻量级的特性,常被用作Hibernate的默认CacheProvider。本教程将详细讲解如何在SpringBoot项目中集成并使用Ehcache。 #...
在Spring配置文件(如`applicationContext.xml`)中,定义Ehcache的相关配置: ```xml <bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean"> ...
压缩包中的文档将详细解释Ehcache的配置、API使用、最佳实践等,建议仔细阅读,以便更好地理解和应用Ehcache。 总结,Ehcache作为页面缓存技术,通过有效的数据存储和检索策略,可以显著提升Web应用性能。通过合理...
本篇将基于提供的"ehcache_test"压缩包文件,详细介绍如何在Java项目中进行Ehcache的配置和使用。 1. **Ehcache简介** Ehcache是一个高性能、轻量级的缓存解决方案,支持本地内存缓存和分布式缓存。它可以被集成到...
- **Spring整合**:如果项目使用Spring,还需要在`applicationContext.xml`中配置MyBatis和Ehcache的bean,使MyBatis能够识别并使用Ehcache作为缓存。 - **Mapper配置**:在Mapper接口或者XML配置文件中,使用`@...
理解和熟练掌握Ehcache的使用,对于优化Java应用程序的性能至关重要。通过合理的配置和最佳实践,开发者可以构建出高效、稳定的缓存系统,有效应对大数据量和高并发场景。在实际项目中,结合Ehcache的文档,例如...
### Spring Boot集成Ehcache实现缓存 ...Ehcache的高效性和灵活性使得其成为许多Java应用中缓存管理的首选方案之一。在实际开发过程中,根据业务需求合理配置缓存策略,能够有效提升系统的整体性能和用户体验。