缓存异常与一致性

  • 缓存异常:
    • 缓存穿透:请求缓存和数据库都不存在的数据,每次都要查数据库,缓存好像没有起到拦截流量作用。
      • 采用布隆过滤器过滤一定不存在key请求、key逻辑校验,不存在key请求设置缓存key-null
      • 布隆过滤器采用多个hash函数,若请求的key的多个hash值都存在,则可能存在,否则一定不存在
    • 缓存击穿:缓存热key过期,导致大量请求打到数据库上
      • 采用热key续期,重建缓存加互斥锁
    • 缓存雪崩:大量缓存key过期,大量请求打到数据库
      • 采用过期时间设置随机,防止同时大量缓存过期
  • 缓存一致性:
    • 更新mysql后,不管redis,由过期时间兜底
    • 更新mysql后也写入redis,可能有时序性问题,更常用直接删除,下次再加载缓存
    • 通过消息队列订阅mysql的binlog,实现缓存一致性,适用于缓存基本不过期时间的场景
相关推荐
程序员勋勋15 小时前
Redis的String数据类型底层实现
数据库·redis·缓存
YouQian7725 小时前
(AC)缓存系统
算法·缓存
KNeeg_6 小时前
Spring循环依赖以及三个级别缓存
java·spring·缓存
lkf197116 小时前
商品中心—1.B端建品和C端缓存
开发语言·后端·缓存
小王子102412 小时前
Django缓存机制详解:从配置到实战应用
redis·缓存·django·rbac
Antonio91512 小时前
【Redis】Redis 数据存储原理和结构
数据库·redis·缓存
problc14 小时前
大模型API和秘钥获取地址
数据库·redis·缓存
Rover.x15 小时前
内存泄漏问题排查
java·linux·服务器·缓存
木宇(记得热爱生活)15 小时前
Qt GUI缓存实现
开发语言·qt·缓存
Antonio91518 小时前
【Redis】 Redis 基础命令和原理
数据库·redis·缓存