Springboot集成Ehcache3实现本地缓存

embedded/2024/9/23 6:22:50/

如果只需要在单个应用程序中使用本地缓存,则可以选择Ehcache;它支持内存和磁盘存储,这里不以注解方式演示,通过自己实现缓存管理者灵活控制缓存的读写;

1、引入相关依赖

		<!-- ehcache3集成start --><dependency><groupId>org.ehcache</groupId><artifactId>ehcache</artifactId><version>3.10.8</version></dependency><dependency><groupId>javax.cache</groupId><artifactId>cache-api</artifactId></dependency><!-- ehcache3集成end -->

2、修改yml配置

spring:cache:type: jcachejcache:config: classpath:cache/ehcache.xml

3、配置ehcache.xml文件

<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-3.0.xsd"><!-- 缓存持久化配置: 定义磁盘缓存位置 --><persistence directory="E:/project_home/limit_control/cache/light-element-mybatis"/><!-- 缓存模板: 未填写缓存名时使用的默认缓存,同时也可被继承 --><cache-template name="defaultCache"><key-type>java.lang.String</key-type><value-type>java.lang.Object</value-type><resources><heap unit="MB">64</heap><offheap unit="MB">128</offheap></resources></cache-template><!-- 缓存列表: 自定义缓存配置 --><!-- 不过期 --><cache alias="EXPIRE_NONE" uses-template="defaultCache"/><!-- 24小时过期 --><cache alias="EXPIRE_24_HOURS" uses-template="defaultCache"><expiry><ttl unit="hours">24</ttl></expiry></cache><!-- 30分钟过期 --><cache alias="EXPIRE_30_MINUTES" uses-template="defaultCache"><expiry><ttl unit="minutes">30</ttl></expiry></cache>
</config>

4、编写缓存策略枚举

public enum CacheStrategy {EXPIRE_30_MINUTES,EXPIRE_24_HOURS,EXPIRE_NONE
}

5、编写缓存管理者,来控制缓存的增删改查

import com.alibaba.fastjson.JSON;
import org.springframework.cache.Cache;
import org.springframework.cache.CacheManager;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.context.annotation.Configuration;import java.util.List;/*** ehcache3缓存管理者*/
@Configuration
@EnableCaching
public class EhCacheManager {private static CacheManager cacheManager;public EhCacheManager(CacheManager cacheManager) {EhCacheManager.cacheManager = cacheManager;}/*** 获取默认缓存** @return*/public static Cache getDefaultCache() {return getCache("EXPIRE_24_HOURS");}/*** 获取指定缓存** @param cacheName 缓存名称* @return*/public static Cache getCache(String cacheName) {if (cacheManager == null) {return null;}return cacheManager.getCache(cacheName);}/*** 获取缓存内容(对象)** @param cacheName 缓存名称* @param key       键* @param clazz<T>  class类型* @return*/public static <T extends Object> T getObjValue(String cacheName, String key, Class<T> clazz) {Object o = getValue(cacheName, key);if (o == null) {return null;}T t = (T) JSON.parseObject(JSON.toJSONString(o), clazz);return t;}/*** 获取缓存内容(集合)** @param cacheName 缓存名称* @param key       键* @param clazz<T>  class类型* @return*/public static <T extends Object> List<T> getListValue(String cacheName, String key, Class<T> clazz) {Object o = getValue(cacheName, key);if (o == null) {return null;}List<T> ts = JSON.parseArray(JSON.toJSONString(o), clazz);return ts;}/*** 获取缓存内容** @param cacheName* @param key* @return*/private static Object getValue(String cacheName, String key) {Cache cache = getCache(cacheName);if (cache == null && cache.get(key) == null) {return null;}Cache.ValueWrapper valueWrapper = cache.get(key);if (valueWrapper == null) {return null;}Object o = valueWrapper.get();if (o == null) {return null;}return o;}/*** 新增或修改缓存数据** @param cacheName 缓存名称* @param key       键* @param value     值*/public static void put(String cacheName, String key, Object value) {Cache cache = getCache(cacheName);if (cache == null) {return;}cache.put(key, value);}/*** 删除缓存数据** @param cacheName 缓存名称* @param key       键*/public static void del(String cacheName, String key) {Cache cache = getCache(cacheName);if (cache == null) {return;}cache.evict(key);}
}

6、编写controller进行简单测试

import cn.hutool.core.collection.CollectionUtil;
import com.yx.light.element.mybatis.cache.CacheStrategy;
import com.yx.light.element.mybatis.cache.EhCacheManager;
import com.yx.light.element.mybatis.mapper.entity.GroupHeader;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.util.ArrayList;
import java.util.List;@RestController
@RequestMapping(value = "/index")
@Slf4j
public class IndexController {@GetMapping(value = "/list")public List<GroupHeader> list() {List<GroupHeader> listValue = EhCacheManager.getListValue(CacheStrategy.EXPIRE_30_MINUTES.name(), "list", GroupHeader.class);if (CollectionUtil.isEmpty(listValue)) {log.info("集合缓存不存在或已过期,查询数据库!");//模拟查库List<GroupHeader> objects = new ArrayList<>();for (int i = 0; i < 5; i++) {GroupHeader groupHeader = new GroupHeader();groupHeader.setGroupCode("aaaaa-" + i);groupHeader.setGroupName("多个对象" + i);objects.add(groupHeader);}listValue = objects;EhCacheManager.put(CacheStrategy.EXPIRE_30_MINUTES.name(), "list", listValue);log.info("集合数据加载到缓存!");} else {log.info("从集合缓存中直接获取数据!");}return listValue;}@GetMapping(value = "/one")public GroupHeader one() {GroupHeader objValue = EhCacheManager.getObjValue(CacheStrategy.EXPIRE_30_MINUTES.name(), "obj", GroupHeader.class);if (objValue == null) {log.info("对象缓存不存在或已过期,查询数据库!");//模拟查库GroupHeader groupHeader = new GroupHeader();groupHeader.setGroupCode("aaaaa");groupHeader.setGroupName("单个对象");objValue = groupHeader;EhCacheManager.put(CacheStrategy.EXPIRE_30_MINUTES.name(), "obj", groupHeader);log.info("对象数据加载到缓存!");} else {log.info("从对象缓存中直接获取数据!");}return objValue;}@GetMapping(value = "/del")public void del() {log.info("清理对象缓存!");EhCacheManager.del(CacheStrategy.EXPIRE_30_MINUTES.name(), "obj");}}

7、分别调用接口查看日志打印


http://www.ppmy.cn/embedded/7273.html

相关文章

软件测试的经验和教训

1. 认知心理学是测试的基础。 >>>对事物的认知程度&#xff0c;才能对事物做出评价。对事物没有任何认知和了解&#xff0c;就不会有判断<<< 2. 与测试有关的一些问题&#xff1a; a.人的感觉和记忆可靠性 b.信念从哪里来 c.信念如何影响人的行为 d.做…

封装原生html的table处理方法【参数类似eltable】

直接跑html即可 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>封装原生talbe</title> </…

【贪玩巴斯】Vm/ubantu虚拟机报错04005和70057解决方法如下(基于WindowsX64系统)

&#x1f4da;Vm/ubantu虚拟机报错04005和70057解决方法如下&#xff08;基于WindowsX64系统&#xff09;&#xff1a; 错误1场景描述&#xff1a;04005 返回 代码:E_FAIL (0X80004005)组件:SessionMachine界面:ISession {c0447716-ff5a-4795-b57a-ecd5fffa18a4}打开电脑启动虚…

mapreduce中的ReduceTask工作机制(Hadoop)

ReduceTask 是 Hadoop 中的一个重要组件&#xff0c;负责对 MapTask 的输出进行合并、排序和归并&#xff0c;最终生成最终的输出结果。 ReduceTask 的工作机制 1. 分组&#xff08;Shuffle&#xff09;阶段&#xff1a; 在分组阶段&#xff0c;ReduceTask 会从多个 Mapper …

Spark---核心概念(Spark,RDD,Spark的核心构成组件)详解

一、什么是Spark Spark就是一个集成离线计算&#xff0c;实时计算&#xff0c;SQL查询&#xff0c;机器学习&#xff0c;图计算为一体的通用的计算框架。 二、Spark特点 1、速度快 相比较于MR&#xff0c;官方说&#xff0c;基于内存计算spark要快mr100倍&#xff0c;基于磁…

在线拍卖系统,基于SpringBoot+Vue+MySql开发的在线拍卖系统设计和实现

目录 一. 系统介绍 二. 功能模块 2.1. 管理员功能模块 2.2. 用户功能模块 2.3. 前台首页功能模块 2.4. 部分代码实现 一. 系统介绍 随着社会的发展&#xff0c;社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 在线拍卖系…

centos 6设置yum源遇到的问题

由于centos6已经不被支持了&#xff0c;直接抄人家的命令是不行的 比如执行这些&#xff08;是wget或者是curl按照自己的改&#xff09; wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo yum makecache会报错 需要到对应的镜像源网…

win docker clickhouse 挂载本地目录到容器后无法写入数据问题解决

win docker 部署clickhouse 挂载本地目录到容器后无法写入数据问题具体错误提示代码尝试在docker compose 文件中添加文件操作的许可进一步在docker compose 中配置 ulimits参数如下修改映射的本地目录到d盘最后使用docker的数据卷来映射到容器内部目录&#xff0c;解决了不能…