spring boot和缓存(尤其是堆内缓存)结合使用,如何解决缓存的雪崩问题

2023-12-16 10:08

本文主要是介绍spring boot和缓存(尤其是堆内缓存)结合使用,如何解决缓存的雪崩问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以ehcache为例

spring boot和ehcache结合后,ehcache的配置文件是写死超时时间的。

举例如下:

         <diskStore path="/tmp/dcep"/><cacheManagerPeerProviderFactory
class="net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory"
properties="peerDiscovery=automatic, multicastGroupAddress=230.0.0.1,
multicastGroupPort=4446, timeToLive=1"/><cacheManagerPeerListenerFactoryclass="net.sf.ehcache.distribution.RMICacheManagerPeerListenerFactory"properties="socketTimeoutMillis=2000"/><cache name="properties"maxBytesLocalHeap="100M"  eternal="false"   overflowToDisk="false"timeToLiveSeconds="100000"copyOnRead="true"copyOnWrite="true"><!-- 以下配置ehcache cluster,集群具有逐出、互相通信等功能,仅能做有限的分布式一致性,作为一级缓存,不建议配置集群功能,ehcache 不建议使用在对一致性要求高的地方 -->
<!--     <cacheEventListenerFactory -->
<!--         class="net.sf.ehcache.distribution.RMICacheReplicatorFactory" -->
<!--         properties="replicateAsynchronously=false,  -->
<!--     replicatePuts=false,  -->
<!--     replicateUpdates=false, -->
<!--         replicateUpdatesViaCopy=false,  -->
<!--     replicateRemovals=true "/> --></cache>

文中timeToLiveSeconds就是超时时间。代码中都配置使用这个properties的cache的时候,就会同时在timeToLiveSeconds后失效,同时访问数据库,造成缓存雪崩。

解决方案:

    @Beanpublic CacheManagerCustomizers cacheManagerCustomizers(EhCachePropertiesConfig ehCachePropertiesConfig) {return new CacheManagerCustomizers(Arrays.asList(ehCacheCacheManager->{if(ehCacheCacheManager instanceof EhCacheCacheManager){net.sf.ehcache.CacheManager nativeEhCacheManager = ((EhCacheCacheManager)ehCacheCacheManager).getCacheManager();ehCachePropertiesConfig.reSetConfig(nativeEhCacheManager);}}));}

生成一个CacheManagerCustomizers的bean。spring boot会判断该bean是否存在,如果存在,则使用用户生成的这个bean。

在生成ehcachecachemanager后,可以通过这个bean对cache进行修改。在上面代码中,通过这个类,对ehcachecachemanager进行cache配置的修改。

resetconfig代码如下:

@Component
public class EhCachePropertiesReset implements EhCachePropertiesConfig {//向上波动最大值int maxVariation = 10;Random rand = new Random();@Overridepublic void reSetConfig(CacheManager cacheManager) {// TODO Auto-generated method stubMap<String, CacheConfiguration> configByCacheName = cacheManager.getConfiguration().getCacheConfigurations();configByCacheName.forEach((k,v)->{long timeToLiveSeconds = v.getTimeToLiveSeconds();if(timeToLiveSeconds != 0){int variation = rand.ints(0, maxVariation).findFirst().orElse(0);long newTimeLiveSeconds = timeToLiveSeconds + variation;v.setTimeToLiveSeconds(newTimeLiveSeconds);//这一步真正设置每一个cache的过期时间cacheManager.getCache(k).getCacheConfiguration().setTimeToLiveSeconds(newTimeLiveSeconds);}}); }
}

通过随机化方法,对在配置文件中配置的数值进行随机化扰动。

这篇关于spring boot和缓存(尤其是堆内缓存)结合使用,如何解决缓存的雪崩问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/500091

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja