一、简介

  EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点。Ehcache是一种广泛使用的开源Java分布式缓存。主要面向通用缓存,Java EE和轻量级容器。它具有内存和磁盘存储,缓存加载器,缓存扩展,缓存异常处理程序,一个gzip缓存servlet过滤器,支持REST和SOAP api等特点。  

  主要的特性有:

  1. 快速
  2. 简单
  3. 多种缓存策略
  4. 缓存数据有两级:内存和磁盘,因此无需担心容量问题
  5. 缓存数据会在虚拟机重启的过程中写入磁盘
  6. 可以通过RMI、可插入API等方式进行分布式缓存
  7. 具有缓存和缓存管理器的侦听接口
  8. 支持多缓存管理器实例,以及一个实例的多个缓存区域
  9. 提供Hibernate的缓存实现

二、详细配置

  EhCache 给我们提供了丰富的配置来配置缓存的设置。

cache元素的属性:

name:缓存名称

maxElementsInMemory:内存中最大缓存对象数

maxElementsOnDisk:硬盘中最大缓存对象数,若是0表示无穷大

eternal:true表示对象永不过期,此时会忽略timeToIdleSeconds和timeToLiveSeconds属性,默认为false

overflowToDisk:true表示当内存缓存的对象数目达到了maxElementsInMemory界限后,会把溢出的对象写到硬盘缓存中。注意:如果缓存的对象要写入到硬盘中的话,则该对象必须实现了Serializable接口才行。

  diskSpoolBufferSizeMB:磁盘缓存区大小,默认为30MB。每个Cache都应该有自己的一个缓存区。

diskPersistent:是否缓存虚拟机重启期数据

diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认为120秒

timeToIdleSeconds: 设定允许对象处于空闲状态的最长时间,以秒为单位。当对象自从最近一次被访问后,如果处于空闲状态的时间超过了timeToIdleSeconds属性值,这个对象就会过期,EHCache将把它从缓存中清空。只有当eternal属性为false,该属性才有效。如果该属性值为0,则表示对象可以无限期地处于空闲状态

timeToLiveSeconds:设定对象允许存在于缓存中的最长时间,以秒为单位。当对象自从被存放到缓存中后,如果处于缓存中的时间超过了 timeToLiveSeconds属性值,这个对象就会过期,EHCache将把它从缓存中清除。只有当eternal属性为false,该属性才有效。如果该属性值为0,则表示对象可以无限期地存在于缓存中。timeToLiveSeconds必须大于timeToIdleSeconds属性,才有意义

memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。可选策略有:LRU(最近最少使用,默认策略)、FIFO(先进先出)、LFU(最少访问次数)。

三、持久化到硬盘

  在一些系统中,使用EhCache来缓存数据的时候,有时是不需要持久化到硬盘的,但是在爬虫系统,就需要将数据 持久化到硬盘,用来判断URL是否重复,也就是对爬取过去的URL进行过滤,避免重复爬取。

  参考配置:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2
 3 <ehcache>
 4    <!--
 5          磁盘存储:将缓存中暂时不使用的对象,转移到硬盘,类似于Windows系统的虚拟内存
 6           path:指定在硬盘上存储对象的路径
 7    -->
 8    <diskStore path="C:\ehcache" />
 9
10    <!--
11         defaultCache:默认的缓存配置信息,如果不加特殊说明,则所有对象按照此配置项处理
12         maxElementsInMemory:设置了缓存的上限,最多存储多少个记录对象
13         eternal:代表对象是否永不过期
14         overflowToDisk:当内存中Element数量达到maxElementsInMemory时,Ehcache将会Element写到磁盘中
15    -->
16    <defaultCache
17       maxElementsInMemory="100"
18       eternal="true"
19       overflowToDisk="true"/>
20
21     <!--
22         maxElementsInMemory设置成1,overflowToDisk设置成true,只要有一个缓存元素,就直接存到硬盘上去
23         eternal设置成true,代表对象永久有效
24         maxElementsOnDisk设置成0 表示硬盘中最大缓存对象数无限大
25         diskPersistent设置成true表示缓存虚拟机重启期数据
26      -->
27     <cache
28       name="a"
29       maxElementsInMemory="1"
30       eternal="true"
31       overflowToDisk="true"
32       maxElementsOnDisk="0"
33       diskPersistent="true"/>
34
35 </ehcache>

四、实例

  此处使用的EhCache版本为2.X,此版本比较稳定。

1.pom.xml

    <dependency><groupId>net.sf.ehcache</groupId><artifactId>ehcache</artifactId><version>2.10.4</version></dependency>

2.代码实现

 1     public static void main(String[] args) {
 2         String path = System.getProperty("user.dir");
 3         // 创建Cache管理器
 4         CacheManager manager = CacheManager.create(path + "\\src\\main\\resources\\ehcache.xml");
 5         // 获取指定Cache
 6         Cache cache = manager.getCache("a");
 7         // 把一个元素添加到Cache中
 8         cache.put(new Element("name", "Joe"));
 9         // 根据Key获取缓存元素
10         Element ele = cache.get("name");
11         System.out.println("name==" + ele.getObjectValue());
12
13         cache.flush(); // 刷新缓存
14         manager.shutdown();  // 关闭缓存管理器
15     }

3.查看C盘中的ehcache文件夹,有如下文件,说明缓存到磁盘中了。

EhCache初体验相关推荐

  1. 苹果电脑安装python3密码_mac系统安装Python3初体验

    前沿 对于iOS开发不要随便拆卸系统自带的Python,因为有很多 library 还是使用 Python2.7. 1 安装Xcode 1.1 App Store 搜索Xcode 并安装 1.2 安装 ...

  2. MapReduce编程初体验

    需求:在给定的文本文件中统计输出每一个单词出现的总次数 第一步: 准备一个aaa.txt文本文档 第二步: 在文本文档中随便写入一些测试数据,这里我写入的是 hello,world,hadoop he ...

  3. 小程序 缩放_缩放流星应用程序的初体验

    小程序 缩放 by Elie Steinbock 埃莉·斯坦博克(Elie Steinbock) 缩放流星应用程序的初体验 (First Experiences Scaling a Meteor Ap ...

  4. wxWidgets刚開始学习的人导引(3)——wxWidgets应用程序初体验

    wxWidgets刚開始学习的人导引全文件夹   PDF版及附件下载 1 前言 2 下载.安装wxWidgets 3 wxWidgets应用程序初体验 4 wxWidgets学习资料及利用方法指导 5 ...

  5. 用鸿蒙跑了个 “hello world”!鸿蒙开发初体验

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 来源 | https://my.oschina.net/u ...

  6. Windows Embedded Standard开发初体验(二)

    支持Silverlight的Windows Embedded Standard 好了,完成安装之后,我们就可以来做Windows Embedded Standard的第一个操作系统镜像了.在开始菜单中 ...

  7. 深度探索Hyperledger技术与应用之超级账本初体验(附部署代码)

    2019独角兽企业重金招聘Python工程师标准>>> 本章零基础地介绍了如何快速体验超级账本搭建的区块链网络,我们先绕过了比较复杂的初始化配置,用官方提供的fabric-sampl ...

  8. Spring环境搭建,IoC容器初体验~

    由于最近的任务是关于IoC配置文件格式的转换,所以需要从Spring的IoC容器开始学起,今天根据网上的介绍搭建了Spring环境,并对其IoC容器进行了初体验.文章中涉及到的软件以及推荐的一本关于S ...

  9. 来自新手Banana Pi香蕉派初体验

    2019独角兽企业重金招聘Python工程师标准>>> 一.前言 一段时间来对有强大的技术支持和完善的社区的Raspberry Pi很感兴趣,本想入一片学习学习,但转念一想Raspb ...

  10. 《深入理解Spark:核心思想与源码分析》——1.2节Spark初体验

    本节书摘来自华章社区<深入理解Spark:核心思想与源码分析>一书中的第1章,第1.2节Spark初体验,作者耿嘉安,更多章节内容可以访问云栖社区"华章社区"公众号查看 ...

最新文章

  1. F - Count the Colors - zoj 1610(区间覆盖)
  2. UpSetR 高级参数使用教程
  3. mq系列传感器的程序_深圳现代通信系列实训系统
  4. 五种方法查看Ubuntu/Redhat等Linux系统版本号等系统信息
  5. 同余(数论) AcWing算法课
  6. [转:有种感觉叫佩服]一个程序员的奋斗历程
  7. 微软作为金牌会员加入Cloud Foundry基金会
  8. Nand Flash Yaffs系统大量写入数据失败问题的解决方法。
  9. 获取系统信息1——linux系统中的时间
  10. mysql操作json优点和缺点_SQL-mysql操作json
  11. eNSP重装之后,启动路由器时注册失败
  12. AdRotator,广告轮播 #1 -- 透过XML档来作设定。
  13. mybatis逆向工程详解
  14. 数据预处理之数据清洗案例
  15. java用户行为日志记录方法_简单易用的开源用户操作日志记录系统
  16. 【UTM使用_入侵防御策略】
  17. 跟着团子学SAP SD:项目里程碑开票流程演示(含预收账款“开票”及正式开票) VF01
  18. 2019年寒假 纪中培训总结
  19. HihoCoder - 1318 非法二进制数(找规律,BM线性递推)
  20. Failed to decode downloaded font(线上环境字体图标不显示)

热门文章

  1. Word中如何输入花体数学字符
  2. 安卓原生系统_有效解决跳过原生安卓系统开机验证问题的方法,赶快上车
  3. 自动更改IP地址反爬虫封锁
  4. seaweedfs java_seaweedfs-java-client
  5. 线性表的链式存储结构 ( 链表 )
  6. C语言面试题---函数(一)
  7. Java中String字符串长度
  8. 博图注册表删除方法_【博图+仿真+授权】西门子软件安装指南及注意事项
  9. PID参数整定快速入门(调节器参数整定方法)
  10. ArcGIS 各版本产品补丁荟萃