缓存异常与一致性

  • 缓存异常:
    • 缓存穿透:请求缓存和数据库都不存在的数据,每次都要查数据库,缓存好像没有起到拦截流量作用。
      • 采用布隆过滤器过滤一定不存在key请求、key逻辑校验,不存在key请求设置缓存key-null
      • 布隆过滤器采用多个hash函数,若请求的key的多个hash值都存在,则可能存在,否则一定不存在
    • 缓存击穿:缓存热key过期,导致大量请求打到数据库上
      • 采用热key续期,重建缓存加互斥锁
    • 缓存雪崩:大量缓存key过期,大量请求打到数据库
      • 采用过期时间设置随机,防止同时大量缓存过期
  • 缓存一致性:
    • 更新mysql后,不管redis,由过期时间兜底
    • 更新mysql后也写入redis,可能有时序性问题,更常用直接删除,下次再加载缓存
    • 通过消息队列订阅mysql的binlog,实现缓存一致性,适用于缓存基本不过期时间的场景
相关推荐
ytgytg2814 小时前
HC小区管理系统安装,提示redis连接错误
数据库·redis·缓存
Grassto16 小时前
11 Go Module 缓存机制详解
开发语言·缓存·golang·go·go module
he___H18 小时前
Redis高级特性
数据库·redis·缓存
crossaspeed18 小时前
Redis的持久化(八股)
数据库·redis·缓存
怡步晓心l19 小时前
Mandelbrot集合的多线程并行计算加速
c++·算法·缓存
三水不滴21 小时前
Redis 故障转移:哨兵vs集群
数据库·经验分享·redis·缓存·性能优化
鸽芷咕1 天前
从 Query Mapping 到函数缓存,KingbaseES 高级 SQL 调优手段全揭秘
数据库·sql·缓存·金仓数据库
曹天骄1 天前
基于 Cloudflare 的双层缓存架构实践:CDN Cache 与 Worker Cache 的职责分离设计
缓存·架构
Looooking1 天前
Python 之 cachetools 缓存工具
缓存
huohuopro1 天前
Redis安装和杂谈
数据库·redis·缓存