当前位置:网站首页 > Java教程 > 正文

java ehcache教程



Ehcache 是一个开源的高性能缓存,拥有很高的拓展性和伸缩性,广泛使用各种 Java 项目中(如 Hibernate 默认使用 Ehcache作为二级缓存),在目前基于 Java 的缓存方案里,几乎是性能最高的实现。

配置Ehcache有两种方式:编码配置、 配置文件配置

 
  1. 通过构建器模式定义了别名为feilcache的缓存,key、value均为String。JVM byted-size 堆缓存设置大小。
  2. 进行init初始化。
  3. 通过别名获取缓存并添加缓存。
  4. 最后不要忘记最重要的关闭资源。

Ehcache3.x提供了一种分层模型。ehcache 的缓存储存主要分为以下3层:

  • heap:JVM byted-size 堆缓存,速度最快;
  • off-heap:JVM 堆外内存,速度低于 heap,但是高于 disk;
  • disk:磁盘储存,速度最低,相对于 heap ,off-heap可以分配大量资源空间;

上面的例子分配了非常少量的堆外。请记住,堆外存储的数据必须被序列化和反序列化 - 因此比堆慢。因此,您应该支持大量数据的堆外堆,其中堆上会对垃圾收集产生太严重的影响。不要忘记-XX:MaxDirectMemorySize根据您打算使用的堆外大小在java选项中定义该选项。

如果您希望使用磁盘存储(例如对于持久Cache实例),则必须提供将数据存储在磁盘上的CacheManagerBuilder.persistence(String)静态方法的位置。

定义磁盘的资源池。第三个参数是一个布尔值,用于设置磁盘池是否持久。设置为true时,池是持久的,当设置为false时,池不是持久的。如果在没有第三个布尔参数的情况下使用此方法,则池不是持久的。

<cache alias="foo">
<key-type>java.lang.String</key-type>
<resources>
<heap unit="entries">2000</heap>
<offheap unit="MB">500</offheap>
</resources>
</cache>

<cache-template name="myDefaults">
<key-type>java.lang.Long</key-type>
<value-type>java.lang.String</value-type>
<heap unit="entries">200</heap>
</cache-template>

<cache alias="bar" uses-template="myDefaults">
<key-type>java.lang.Number</key-type>
</cache>

<cache alias="simpleCache" uses-template="myDefaults" />

1.声明Cache别名foo
2.密钥foo被声明为类型String; 由于未指定值类型,因此值将为type Object。
3.foo 声明在堆上最多可容纳2,000个条目......以及在开始驱逐之前最多500 MB的堆外内存
4.<cache-template>使用元素可以创建一个抽象配置,进一步<cache>配置可以扩展
5.bar是这样的Cache。 bar使用<cache-template>命名myDefaults并覆盖key-type更广泛的类型。
6.simpleCache是另一个这样的Cache。它使用myDefaults配置为其唯一CacheConfiguration。

为了解析XML配置,您可以使用以下类型:

final URL myUrl = this.getClass().getResource("/my-config.xml");
Configuration xmlConfig = new XmlConfiguration(myUrl);
CacheManager myCacheManager = CacheManagerBuilder.newCacheManager(xmlConfig);

1.获取URLXML文件的位置
2.实例化XmlConfiguration将XML文件的URL传递给它
3.使用静态org.ehcache.config.builders.CacheManagerBuilder.newCacheManager(org.ehcache.config.Configuration)可以CacheManager使用Configurationfrom 来创建实例XmlConfiguration

  • 上一篇: java compare 使用教程
  • 下一篇: java教程379
  • 版权声明


    相关文章:

  • java compare 使用教程2025-03-21 17:50:04
  • java基础教程1272025-03-21 17:50:04
  • java函数基础教程2025-03-21 17:50:04
  • java分组查询教程2025-03-21 17:50:04
  • 非正式会谈java教程2025-03-21 17:50:04
  • java教程3792025-03-21 17:50:04
  • java基本运算教程2025-03-21 17:50:04
  • 大学用的java 教程视频教程2025-03-21 17:50:04
  • thrift java 教程2025-03-21 17:50:04
  • java自学体系教程2025-03-21 17:50:04