缓存过期时间之逻辑过期

1. 物理不过期(Physical Non-Expiration)
  • 定义 :在Redis中不设置EXPIRE时间,缓存键永久存在(除非主动删除或内存淘汰)。

  • 目的:彻底规避因缓存自动过期导致的击穿(单热点失效)和雪崩(多键集中失效)。

  • 数据示例

    复制代码
    SET user:1001:profile "{\"name\":\"Alice\",\"last_update\":1690000000}"  # 不设置TTL
2. 逻辑过期(Logical Expiration)
  • 定义:在缓存值的元数据中嵌入过期时间戳,业务层自行判断数据新鲜度。

  • 实现方式

    复制代码
    {
      "data": "真实业务数据",
      "expire_time": 1690003600  // 逻辑过期时间戳
    }
  • 触发更新条件

    • 定时任务扫描:后台线程周期性检查逻辑过期时间,主动更新临近过期的数据。
    • 被动触发更新:当业务请求发现数据逻辑过期时,触发异步更新(需结合降级策略)。
3. 后台异步更新(Background Update)
  • 技术实现

    • 独立线程池:与主业务线程隔离,避免更新操作阻塞正常请求。
    • 双缓冲机制:更新时生成新缓存副本,原子替换旧数据,避免脏读。
  • 流程图

    复制代码
    业务请求 → 读取缓存 → 判断逻辑过期 → 否 → 返回数据
                                  ↓是
                              发起到消息队列 → 后台Worker消费 → 更新DB → 刷新缓存

二、逻辑过期解决缓存击穿的实践

1. 缓存击穿(Cache Breakdown)
  • 传统问题场景:热点Key突然失效,瞬时高并发请求穿透至数据库。
  • 本方案优势
    • 无物理失效:热点Key永不自动删除,直接避免击穿触发条件。
    • 逻辑更新异步化 :即使业务认为数据过期,更新操作由后台线程异步处理,前端请求无需等待,降级返回稍旧数据或进入队列等待。
相关推荐
jason.zeng@150220722 分钟前
Androidr入门环境搭建
java·kotlin
摇滚侠26 分钟前
整洁的桌面和任务栏 Java 开发工程师提效方法
java·开发语言
千月落35 分钟前
Redis数据迁移
数据库·redis·缓存
每天都要加油呀!1 小时前
多租户中间件适配
java·多租户
014-code1 小时前
Java 并发中的原子类
java·开发语言·并发
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题】【Java基础篇】第29题:静态代理和动态代理的区别是什么
java·开发语言·后端·面试·代理模式
善恶怪客1 小时前
Java-数组和可变参数
java·开发语言
小编码上说1 小时前
LSH(局部敏感哈希)分桶,海量数据下的相似性搜索解决方案
java·spring boot·缓存·langchain4j·lsh·局部敏感哈希·ai调用优化
风筝在晴天搁浅2 小时前
LFU缓存
缓存
计算机_毕业设计2 小时前
java-springboot数字藏品系统 基于 SpringBoot 的区块链数字艺术品交易平台 Java 微服务架构下的加密藏品展示与拍卖系统计算机毕业设计
java·spring boot·课程设计