缓存异常与一致性

  • 缓存异常:
    • 缓存穿透:请求缓存和数据库都不存在的数据,每次都要查数据库,缓存好像没有起到拦截流量作用。
      • 采用布隆过滤器过滤一定不存在key请求、key逻辑校验,不存在key请求设置缓存key-null
      • 布隆过滤器采用多个hash函数,若请求的key的多个hash值都存在,则可能存在,否则一定不存在
    • 缓存击穿:缓存热key过期,导致大量请求打到数据库上
      • 采用热key续期,重建缓存加互斥锁
    • 缓存雪崩:大量缓存key过期,大量请求打到数据库
      • 采用过期时间设置随机,防止同时大量缓存过期
  • 缓存一致性:
    • 更新mysql后,不管redis,由过期时间兜底
    • 更新mysql后也写入redis,可能有时序性问题,更常用直接删除,下次再加载缓存
    • 通过消息队列订阅mysql的binlog,实现缓存一致性,适用于缓存基本不过期时间的场景
相关推荐
Flying pigs~~1 天前
RAG智慧问答项目
数据库·人工智能·缓存·微调·知识库·rag
许彰午1 天前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
凯瑟琳.奥古斯特1 天前
Redis是什么及核心特性
前端·css·redis·缓存
手握风云-2 天前
Redis:不只是缓存那么简单(六)
redis·缓存
啥都会一点的老程,自在地镜强者2 天前
【Agent 缓存技术核心差异化】—商业软件壁垒之前缀缓存(二)Codex和Claude code方案比对篇+过度解读
缓存·ai编程
手握风云-2 天前
Redis:不只是缓存那么简单(五)
缓存
Rust研习社2 天前
Rust 高性能内存缓存 moka 完全指南
开发语言·后端·缓存·rust
快乐非自愿3 天前
Redis--SDS字符串与集合的底层实现原理
数据库·redis·缓存
白晨并不是很能熬夜3 天前
【RPC】第 4 篇:服务发现 — Zookeeper + 缓存容错
java·后端·程序人生·缓存·zookeeper·rpc·服务发现
手握风云-3 天前
Redis:不只是缓存那么简单(四)
redis·缓存