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));
        });
    }
}
相关推荐
leeyi18 小时前
Checkpoint 机制:Agent 怎么在断电后接着跑
redis·aigc·agent
云技纵横2 天前
一个 @Async 让循环依赖暴雷:Spring 代理的暗坑
redis
犯困蛋挞yy3 天前
用Claude快速解决Redis代码报错反复无解的问题
redis
唐青枫3 天前
Java Spring WebFlux 实战指南:用 Mono、Flux 和 WebClient 写响应式接口
java·spring
小七-七牛开发者3 天前
TokenPilot:让 LLM Agent 长会话成本降 60%+ 的上下文管理
缓存·agent·token·context·上下文·推理成本
咖啡八杯4 天前
GoF设计模式——策略模式
java·后端·spring·设计模式
Flittly5 天前
【AgentScope Java新手村系列】(11)中断与恢复
java·spring boot·spring
dunky6 天前
Spring 的三级缓存与循环依赖
后端·spring
用户3169353811839 天前
Java连接Redis
redis
码云数智-园园10 天前
C++20 Modules 模块详解
java·开发语言·spring