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是一个流行的开源缓存解决方案,用于在Java应用程序中高效地存储和检索数据,以减少数据库负载并提高性能。Ehcache的核心是`ehcache-core-2.6.8.jar`,它提供了缓存管理的基本功能,如缓存创建、缓存...
Ehcache 是一款广泛应用于Java开发中的开源缓存框架,其高效、易用且功能强大的特点使其在处理大量数据快速访问的问题上表现出色。本文将详细介绍Ehcache的基础知识、配置以及如何在实际项目中应用。 1. **Ehcache...
Ehcache是一个开源的Java缓存解决方案,它被广泛用于提高应用程序的性能和响应速度。Ehcache支持在内存和磁盘上存储数据,并且可以配置为分布式缓存,以适应大型分布式系统的需求。由于Ehcache的高效性和易用性,它...
Java Ehcache是一个流行的开源缓存框架,主要用于提高应用程序的性能,通过存储经常访问的数据到内存中,减少对数据库的直接访问。它适用于Java环境,尤其适合处理大量的短期数据,如临时对象、数据库查询结果等。在...
本工具类包括初始化cache 修改缓存容器配置 向指定容器中设置值 取值 删除指定的ehcache容器 删除所有容器 删除容器内所有元素 释放CacheManage 获取所有的cache名称
### Ehcache:Java环境下高效缓存管理的利器 在探讨Ehcache的优缺点之前,我们首先需要了解Ehcache是什么。Ehcache是Java环境下的一款高性能、分布式内存对象缓存系统,它能够显著提高应用的性能和响应速度,尤其在...
基于java的开发源码-ehcache(Java缓存框架 EhCache).zip 基于java的开发源码-ehcache(Java缓存框架 EhCache).zip 基于java的开发源码-ehcache(Java缓存框架 EhCache).zip 基于java的开发源码-ehcache(Java缓存框架 ...
EhCache使用详解,HIBERNATE缓冲
JAVA源码ehcache(Java缓存框架EhCache)
ehcache-spring-annotatios是获得Apache认证的一个开源项目;它大大简化了在Spring应用中基于业界使用广泛的Ehacche-2.0版本实现缓存的技术,1.1.2版本的ehcache-spring-annotations刚刚发布不久,在本文中,我将会...
java资源ehcache(Java缓存框架 EhCache)提取方式是百度网盘分享地址
基于java的开发源码-Ehcache Java 缓存框架.zip 基于java的开发源码-Ehcache Java 缓存框架.zip 基于java的开发源码-Ehcache Java 缓存框架.zip 基于java的开发源码-Ehcache Java 缓存框架.zip 基于java的开发源码-...
**Java缓存框架 EhCache** EhCache是一个广泛使用的开源Java缓存框架,它以其高效、轻量级和易于集成的特性,在Java开发领域中占据了重要的地位。作为进程内缓存解决方案,EhCache能够在应用程序运行时存储数据,...
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缓存框架,广泛用于提高应用程序的性能和响应速度。它允许在内存中存储数据,减少对数据库的访问,从而优化系统性能。以下是对EhCache框架的一些关键知识点的详细说明: 1. **缓存概念**: ...
EhCache是一个高性能、易用且广泛应用于Java环境中的分布式缓存框架。它主要用于提高应用程序的性能和响应速度,通过存储经常访问的数据到内存中,避免频繁地从数据库或者其他慢速资源中读取数据。本资料包将详细...
EhCache是一个高性能、易用且广泛应用于Java环境中的分布式缓存框架,它极大地提高了应用程序的性能和响应速度。在Java开发中,特别是在处理大数据量或频繁读取的数据时,缓存技术是不可或缺的一部分。EhCache作为...
Ehcache是一款广泛使用的开源Java缓存框架,尤其在处理大量数据时,它可以显著提升应用程序的效率。本文将深入探讨Ehcache在实际应用中的实例。 一、Ehcache简介 Ehcache是由Terracotta公司开发的高性能、易用的...
EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点,是Hibernate中默认的CacheProvider。 下图是 Ehcache 在应用程序中的位置: 主要的特性有: 1. 快速.2. 简单.3. 多种缓存策略4. 缓存数据有两级:...