Redis之缓存雪崩问题解决方案

Redis之缓存雪崩问题解决方案

  • 一、介绍
  • 二、解决方法
    • [1. 锁](#1. 锁)
    • [2. 不同的过期时间](#2. 不同的过期时间)
    • [3. 缓存预热和定时任务](#3. 缓存预热和定时任务)

一、介绍

缓存雪崩,指大量的缓存失效,大量的请求又同时落在数据库。主要的一种诱因是key设置的过期时间都一样。

二、解决方法

1. 锁

加锁,每次只让一个线程可以访问数据库,随后存入缓存。性能太差。

2. 不同的过期时间

最简单有效的解决办法是设置不同的过期时间。比如

java 复制代码
int timeout = 10 + new Random().nextInt(20);
redisTemplate.opsForValue().set(key, JSON.toJSONString(coursePublish), timeout, TimeUnit.SECONDS);

3. 缓存预热和定时任务

使用缓存预热,把数据提前放入缓存,然后根据过期时间,发布合理的定时任务,主动去更新缓存。

缓存预热参考代码如下。

java 复制代码
@Component
public class RedisHandler implements InitializingBean {
    @Autowired
    RedisTemplate redisTemplate;
    @Autowired
    CoursePublishMapper coursePublishMapper;

    @Override
    public void afterPropertiesSet() throws Exception {
        List<CoursePublish> coursePublishList = coursePublishMapper.selectList(new LambdaQueryWrapper<CoursePublish>());
        //缓存预热
        coursePublishList.forEach(coursePublish -> {
            String key = "content:course:publish:" + coursePublish.getId();
            redisTemplate.opsForValue().set(key, JSON.toJSONString(coursePublish));
        });
    }
}
相关推荐
m0_4750645016 分钟前
Spring AI RAG简易demo
java·人工智能·spring
液态不合群19 分钟前
一文学习 Spring 声明式事务源码全流程总结
java·学习·spring
xdpcxq102934 分钟前
Redis 故障排查 + 跨语言重构场景实测
数据库·redis·重构
代码探秘者1 小时前
【算法篇】3.位运算
java·数据结构·后端·python·算法·spring
`Jay1 小时前
Python Redis连接池&账号管理池
redis·分布式·爬虫·python·学习
零雲1 小时前
java面试:了解Redis的分布式限流算法么?
java·redis·面试
菜鸟程序员专写BUG2 小时前
SpringBoot整合Redis报错全集|连接超时/序列化/缓存穿透/分布式锁踩坑全解决
spring boot·redis·缓存
MX_93592 小时前
Spring整合Web环境实现思路
java·开发语言·后端·spring
Darkdreams2 小时前
总结 Spring 注入 bean 的四种方式
java·后端·spring
未秃头的程序猿3 小时前
Redis深度突围:告别get/set,解锁高级玩法与性能优化秘籍
redis·后端