1、配置文件ehcache-setting.xml
<?xml version="1.0" encoding="UTF-8"?> <ehcache> <!-- 指定一个文件目录,当EhCache把数据写到硬盘上时,将把数据写到这个文件目录下 --> <diskStore path="c:/tmp" /> <!-- 缓存配置 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:内存数量最大时是否清除。 --> <!-- 设定缓存的默认数据过期策略 --> <defaultCache maxElementsInMemory="10000" eternal="false" overflowToDisk="true" timeToIdleSeconds="10" timeToLiveSeconds="20" diskPersistent="true" diskExpiryThreadIntervalSeconds="120" /> <cache name="hpCache" maxElementsInMemory="3000" eternal="false" overflowToDisk="true" diskPersistent="true" timeToIdleSeconds="10000" timeToLiveSeconds="20000" /> </ehcache>
2、Java 代码直接调用
CacheManager manager = new CacheManager(new ClassPathResource("ehcache-setting.xml").getFile().getAbsolutePath()) ; System.out.println(Arrays.toString(manager.getCacheNames())); Cache cache = manager.getCache("hpCache"); Element e1 = new Element("key1", "黄飞"); Element e2 = new Element("key2", "hf"); cache.put(e1); cache.put(e2); System.out.println( cache.get("key1")); System.out.println( cache.get("key2")) ; //使用flush,和 shutdown后才回持久化到磁盘上,这里和IO一样,不然 数据还在缓冲区域,不会溢写到磁盘 cache.flush(); manager.shutdown();
3、spring中使用
a、配置bean
@Bean(value = "ehcache") public EhCacheManagerFactoryBean ehcache() { EhCacheManagerFactoryBean ehcache = new EhCacheManagerFactoryBean(); try { ehcache.setConfigLocation(new FileSystemResource(new ClassPathResource("ehcache-setting.xml").getFile())); } catch (Exception e) { e.printStackTrace(); } return ehcache; }
b、需要缓存的方法上加入注解
@Cacheable(value="hpCache") public long getTime(String param){ return System.currentTimeMillis() ; }
c、调用测试
System.out.println(cacheService.getTime("1")); Thread.sleep(1000); System.out.println(cacheService.getTime("1"));
4、Ehcache主要特点:
a)快速,简单。在过去众多的测试中已经表明Ehcache是最快的Java缓存之一。
b)多种缓存策略。LRU、LFU和FIFO缓存策略
c)两级缓存数据。内存和磁盘,无需担心容量问题,缓存的数据可伸缩到GB,Ehcache为大数据做过存储优化,在大内存的情况下,所有的进程可以支持数百G的吞吐量。
d)缓存数据会在虚拟机重启的过程中写入磁盘
e)可以通过RMI、api等方式进行分布式缓存。
f)具有缓存和缓存管理器的监听接口。
g)提供hibernate的缓存实现。
5、介绍
Ehcache是用来管理缓存的工具,缓存的数据可以放在内存里,也可以持久化到磁盘上。通过overflowToDisk和diskPersistent来配置。核心是CacheManager,Ehcache的应用都是从CacheManager开始的。一个用过可以有多CacheManager。
6、缓存过期策略
FIFO:根据数据写入时间,先进显出
LFU:最少呗使用缓存元素有一个hit属性,hit最小的将会被清除。
LRU:最近最少被使用。
相关推荐
java ehcache core 2.6.8.jar 核心包和mybatis-ehcache-1.0.3.jar需要版本匹配,匹配回导致执行错误。
Java流行实用ehcache缓存,走过路过不要错过
本工具类包括初始化cache 修改缓存容器配置 向指定容器中设置值 取值 删除指定的ehcache容器 删除所有容器 删除容器内所有元素 释放CacheManage 获取所有的cache名称
基于java的开发源码-ehcache(Java缓存框架 EhCache).zip 基于java的开发源码-ehcache(Java缓存框架 EhCache).zip 基于java的开发源码-ehcache(Java缓存框架 EhCache).zip 基于java的开发源码-ehcache(Java缓存框架 ...
ehcache使用例子,maven项目。
主要介绍了Java Ehcache缓存框架入门级使用实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
java EHCache使用,Hibernate缓存 收集整理
java ehcache terracotta 集群, 分布式缓存配置
EhCache使用详解,HIBERNATE缓冲
简单介绍Ehcache的优缺点
ehcache-spring-annotatios是获得Apache认证的一个开源项目;它大大简化了在Spring应用中基于业界使用广泛的Ehacche-2.0版本实现缓存的技术,1.1.2版本的ehcache-spring-annotations刚刚发布不久,在本文中,我将会...
java源码:ehcache(Java缓存框架 EhCache).rar
基于java的开发源码-Ehcache Java 缓存框架.zip 基于java的开发源码-Ehcache Java 缓存框架.zip 基于java的开发源码-Ehcache Java 缓存框架.zip 基于java的开发源码-Ehcache Java 缓存框架.zip 基于java的开发源码-...
java ehcache分布式缓存实例 RMI方式实现.
java Ehcache新手快速入门
基于Java的ehcache(Java缓存框架 EhCache).zip
基于java的ehcache(Java缓存框架 EhCache).zip
ehcache-2.10.2.jar ,slf4j-api-1.7.7.jarm,slf4j-jdk14-1.7.7.jar,slf4j-log4j12-1.7.7.jar,log4j-1.2.17.jar
jar包 缓存包 分布式框架缓存,适用任何java项目,一个简单的缓存适用工具!
EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点,是Hibernate中默认的CacheProvider。 下图是 Ehcache 在应用程序中的位置: 主要的特性有: 1. 快速.2. 简单.3. 多种缓存策略4. 缓存数据有两级:...