ehcache3介绍和使用示例

news2024/12/25 9:02:57

介绍

EhCache是一个广泛使用的Java进程内缓存框架,具有快速和精干的特点。它提供了以下主要优势:

  • 速度快:由于其直接在JVM进程中运行,EhCache的访问速度非常快,适合对响应时间要求较高的应用。

  • 配置灵活:支持通过XML文件或API进行配置,使得集成和使用变得相对简单。

  • 多种缓存策略:提供内存缓存和磁盘缓存两种级别,以应对不同的数据容量需求。

  • 持久化:缓存数据可以在虚拟机重启过程中写入磁盘,保证数据的持久性。

  • 分布式缓存:支持通过RMI等手段实现分布式缓存,虽然它的分布式缓存功能不如专门的分布式缓存系统如Redis那样强大。
    兼容性好:作为Hibernate的默认缓存提供者,同时也得到Spring Boot和Spring Framework的支持,可以与其他框架如MyBatis、Shiro等结合使用。

使用示例

  • 引入依赖
<dependency>
      <groupId>org.ehcache</groupId>
      <artifactId>ehcache</artifactId>
      <version>3.9.6</version>
    </dependency>
  • 创建ehcache.xml配置文件
<?xml version="1.0" encoding="UTF-8"?>
<config xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
	xmlns='http://www.ehcache.org/v3'
	xsi:schemaLocation="http://www.ehcache.org/v3 http://www.ehcache.org/schema/ehcache-core.xsd">
	<cache alias="USER">
		<key-type>java.lang.String</key-type>
		<value-type>java.lang.String</value-type>
		<expiry>
			<ttl unit="seconds">30</ttl>
		</expiry>
		<resources>
			<heap unit="entries">200</heap>
			<offheap unit="MB">2</offheap>
		</resources>
	</cache>
</config>
  • 定义工具类
/**
 * @author 
 * @Description 
 * @Date 
 **/
public class LocalCacheManager {
	
	private static volatile LocalCacheManager instance;
	private CacheManager cacheManager;
	
	public static LocalCacheManager getInstance() {
		if (instance == null) {
			synchronized (LocalCacheManager.class) {
				if (instance == null) {
					LocalCacheManager i = new LocalCacheManager();
					i.init();
					instance = i;
				}
			}
		}
		return instance;
	}
	
	private void init() {
		URL myUrl = getClass().getResource("/ehcache.xml"); 
		Configuration xmlConfig = new XmlConfiguration(myUrl); 
		cacheManager = CacheManagerBuilder.newCacheManager(xmlConfig);
		cacheManager.init();
	}
	
	public void put(String cacheName, String key, String v) {
		Cache<String, String> c = cacheManager.getCache(cacheName, String.class, String.class);
		c.put(key, v);
	}
	
	public String get(String cacheName, String key) {
		Cache<String, String> c = cacheManager.getCache(cacheName, String.class, String.class);
		return c.get(key);
	}

	public void put(String cacheName, String key, Object value, Class classz) {
		Cache<String, Object> c = cacheManager.getCache(cacheName, String.class, classz);
		c.put(key, value);
	}

	public <V>V get(String cacheName, String key, Class<V> classz) {
		Cache<String, V> c = cacheManager.getCache(cacheName, String.class, classz);
		return c.get(key);
	}
}

ehcache详解

Ehcache 分层选项

移出堆

当在缓存中具有堆层以外的层时,会发生以下几件事:

  • 将映射添加到缓存意味着必须序列化键和值。

  • 从缓存中读取映射意味着可能必须反序列化键和值。

分层配置

在这里插入图片描述

Ehcache支持多种配置选项,包括堆内存(On-Heap)、堆外内存(Off-Heap)和磁盘存储(Disk)。具体如下:

  • 堆内存(On-Heap):这是Ehcache的默认配置,缓存数据存储在Java堆内存中。这种方式访问速度快,但受限于堆内存的大小,不适合存储大量的数据。

  • 堆外内存(Off-Heap):Ehcache允许将缓存数据存储在堆外内存中,这通常是指直接在Java进程的本地内存中分配空间。堆外内存不受Java堆大小的限制,可以用于存储相对较大的数据集,但需要确保数据是可序列化的。

  • 磁盘存储(Disk):当内存不足以容纳所有缓存数据时,Ehcache可以将数据溢出到磁盘上。这适用于存储大量数据,或者作为持久化缓存的一种方式。使用磁盘存储时,缓存的键值对也必须支持序列化和反序列化。

Ehcache 要求堆层的大小小于堆外层的大小,堆外层的大小小于磁盘层的大小。但是要多层可以组合,但是必须有配置堆内存。以下几种均是有效配置:

  • 堆内存(On-Heap)+ 堆外内存(Off-Heap):这个组合允许你利用堆内存的快速访问速度处理热数据,同时使用堆外内存存储更多的温数据,而不会加重GC的负担。

  • 堆内存(On-Heap)+ 磁盘(Disk):此配置适用于需要持久化的场景,磁盘作为冷数据的存储层,保证在应用重启后数据不丢失。

  • 堆内存(On-Heap)+ 堆外内存(Off-Heap)+ 磁盘(Disk):这是最全面的缓存配置,结合了三者的优点,能够应对从热数据到冷数据的不同访问频率和容量需求。

存放数据流程以及获取数据流程

在这里插入图片描述
存放数据时直接将数据存放到最下层的缓存中。
在这里插入图片描述
Ehcache 在获取缓存时会从高层向低层逐级查找,直到最下层,然后将数据存储在更高层并返回。

缓存过期策略

在 Ehcache 3 中,缓存过期通过接口及其在控制缓存映射期限中的使用来解决。

缓存过期配置

<cache alias="withExpiry">
  <expiry>
    <ttl unit="seconds">20</ttl> 
  </expiry>
  <heap>100</heap>
</cache>

过期策略是在缓存级别配置的,因此首先要定义缓存配置,然后添加一个,这里使用预定义的生存时间,配置了所需的ExpiryPolicyDuration。

过期策略

无过期

这意味着缓存映射将永不过期,

生存时间 (ttl)

这意味着缓存映射将在创建后的固定持续时间后过期。

空闲时间 (tti)

这意味着缓存映射将在上次访问缓存映射后的固定持续时间后过期。

自定义过期策略

实现ExpiryPolicy实现自定义过期策略。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1487134.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用 Haproxy 搭建Web群集

Haproxy是目前比较流行的一种群集调度工具&#xff0c;同类群集调度工具有很多&#xff0c;如LVS 和Nginx。相比较而言&#xff0c;LVS.牲能最好&#xff0e;但是搭建相对复杂:Nginx的upstream模块支持群集功能&#xff0e;但是对群集节点健康检查功能不强&#xff0c;性能没有…

GEE:使用ReLu激活函数对单波段图像进行变换(以NDVI为例)

作者:CSDN @ _养乐多_ 本文将介绍在 Google Earth Engine (GEE)平台上,对任意单波段影像进行 ReLu 变换的代码。并以对 NDVI 影像像素值的变换为例。 文章目录 一、ReLu激活函数1.1 什么是 ReLu 激活函数1.2 用到遥感图像上有什么用?二、代码链接三、完整代码一、ReLu激活…

HTML5:七天学会基础动画网页6

CSS3自定义字体 ①&#xff1a;首先需要下载所需字体 ②&#xff1a;把下载字体文件放入 font文件夹里&#xff0c;建议font文件夹与 css 和 image文件夹平级 ③&#xff1a;引入字体&#xff0c;可直接在html文件里用font-face引入字体&#xff0c;分别是字体名字和路径 例…

【C++ 函数栈】栈区保存函数参数和函数调用的过程

目录 1 调用过程 &#x1f64b;‍♂️ 作者&#xff1a;海码007&#x1f4dc; 专栏&#xff1a;C专栏&#x1f4a5; 标题&#xff1a;【C 函数栈】栈区保存函数参数和函数调用的过程❣️ 寄语&#xff1a;人生的意义或许可以发挥自己全部的潜力&#xff0c;所以加油吧&#xff…

循环队列与循环双端队列

文章目录 前言循环队列循环双端队列 前言 1、学习循环队列和循环双端队列能加深我们对队列的理解&#xff0c;提高我们的编程能力。 2、本文循环队列使用的是数组&#xff0c;循环双端队列用的是双向链表 3、题目连接&#xff1a;设计循环队列 &#xff0c;设计循环双端队列。 …

C++面试宝典第34题:整数反序

题目 给出一个不多于5位的整数, 进行反序处理。要求: 1、求出它是几位数。 2、分别输出每一位数字。仅数字间以空格间隔, 负号与数字之间不需要间隔。如果是负数,负号加在第一个数字之前, 与数字没有空格间隔。注意:最后一个数字后没有空格。 3、按逆序输出各位数字。逆序后…

华为od机试C卷-开源项目热度榜单

1、题目描述 某个开源社区希望将最近热度比较高的开源项目出一个榜单&#xff0c;推荐给社区里面的开发者。 对于每个开源项目&#xff0c;开发者可以进行关注(watch)、收藏(star)、fork、提issue、提交合并请求(MR)等。 数据库里面统计了每个开源项目关注、收藏、fork、issue…

适用于恢复iOS数据的 10 款免费 iPhone 恢复软件

现在&#xff0c;您可以获得的 iPhone 的存储容量比大多数人的笔记本电脑和台式电脑的存储容量还要大。虽然能够存储数千张高分辨率照片和视频文件、安装数百个应用程序并随身携带大量音乐库以供离线收听固然很棒&#xff0c;但在一个地方拥有如此多的数据可能会带来毁灭性的后…

LNOI省选祭录

写在前面 大概率爆零 你说得对&#xff0c;但是「辽宁省2024联合省选」是一款由「中国计算机学会」推出的一款「开放世界冒险游戏」&#xff0c;游戏发生在一个被称作「大连大学」的幻想世界&#xff0c;在这里&#xff0c;被神选中的人将被授予「xor魔法手杖」&#xff0c;引…

#WEB前端(浮动与定位)

1.实验&#xff1a; 2.IDE&#xff1a;VSCODE 3.记录&#xff1a; float、position 没有应用浮动前 应用左浮动和右浮动后 应用定位 4.代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><me…

matplotlib直方图

matplotlib直方图 假设你获取了250部电影的时长(列表a中), 希望统计出这些电影时长的分布状态(比如时长为100分钟到120分钟电影的数量, 出现的频率)等信息, 你应该如何呈现这些数据? from matplotlib import pyplot as plt a[131, 98, 125, 131, 124, 139, 131, 117, 128, …

linux逻辑卷管理

一.物理卷&#xff0c;逻辑卷&#xff0c;卷组的关系 二.实验题目 1.业务需要&#xff0c;新增5G硬盘&#xff0c;先对第一块磁盘分区&#xff0c;大小为4G&#xff0c;现在进行逻辑卷划分&#xff0c;卷组名为myvg,逻辑卷名为LV1&#xff0c;大小为2G 2.格式化逻辑卷LV1&#…

【论文阅读】多传感器SLAM数据集

一、M2DGR 该数据集主要针对的是地面机器人&#xff0c;文章正文提到&#xff0c;现在许多机器人在进行定位时&#xff0c;其视角以及移动速度与车或者无人机有着较大的差异&#xff0c;这一差异导致在地面机器人完成SLAM任务时并不能直接套用类似的数据集。针对这一问题该团队…

附加Numpy数组

参考&#xff1a;Append Numpy Array 引言 在数据科学和机器学习领域&#xff0c;处理大规模数据集是一项重要且常见的任务。为了高效地处理数据&#xff0c;numpy是一个非常强大的Python库。本文将详细介绍numpy中的一个重要操作&#xff0c;即如何附加&#xff08;append&a…

【网站项目】308学生档案管理系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

【大数据Hive】hive 多字段分隔符使用详解

目录 一、前言 二、hive默认分隔符规则以及限制 2.1 正常示例&#xff1a;单字节分隔符数据加载示例 2.2 特殊格式的文本数据&#xff0c;分隔符为特殊字符 2.2.1 文本数据的字段中包含了分隔符 三、突破默认限制规则约束 3.1 数据加载不匹配情况 1 3.2 数据加载不匹配…

【Redis 主从复制】

文章目录 1 :peach:环境配置:peach:1.1 :apple:三种配置方式:apple:1.2 :apple:验证:apple:1.3 :apple:断开复制和切主:apple:1.4 :apple:安全性:apple:1.5 :apple:只读:apple:1.6 :apple:传输延迟:apple: 2 :peach:拓扑结构:peach:2.1 :apple:⼀主⼀从结构:apple:2.2 :apple:⼀…

最简单的基于 FFmpeg 的收流器(以接收 RTMP 为例)

最简单的基于 FFmpeg 的收流器&#xff08;以接收 RTMP 为例&#xff09; 最简单的基于 FFmpeg 的收流器&#xff08;以接收 RTMP 为例&#xff09;正文结果工程文件下载参考链接 最简单的基于 FFmpeg 的收流器&#xff08;以接收 RTMP 为例&#xff09; 参考雷霄骅博士的文章…

Easy Graphics Engine on GitHub

Easy Graphics Engine 组织 Easy-Graphics-Engine 此组织的创建是为了方便以后分享和维护项目。目前仅整理了少量几个项目&#xff0c;后面会不断进行扩充。 GitHub EGE 项目列表 ege-project-list 分类整理 GitHub 上使用 EGE 开发的项目&#xff0c;便于用户学习。后续会不断…

操作系统(1)——学习导论(Ⅱ)

目录 小程一言专栏链接: [link](http://t.csdnimg.cn/6grrU) 学习导论&#xff08;Ⅱ&#xff09;操作系统-赏前人佳作大型操作系统大型操作系统的一些特点和功能举例 服务器操作系统服务器操作系统特点和功能举例 多处理器操作系统举例 个人计算机操作系统举例 掌上计算机操作…