- 缓存异常:
- 缓存穿透:请求缓存和数据库都不存在的数据,每次都要查数据库,缓存好像没有起到拦截流量作用。
- 采用布隆过滤器过滤一定不存在key请求、key逻辑校验,不存在key请求设置缓存key-null
- 布隆过滤器采用多个hash函数,若请求的key的多个hash值都存在,则可能存在,否则一定不存在
- 缓存击穿:缓存热key过期,导致大量请求打到数据库上
- 采用热key续期,重建缓存加互斥锁
- 缓存雪崩:大量缓存key过期,大量请求打到数据库
- 采用过期时间设置随机,防止同时大量缓存过期
- 缓存穿透:请求缓存和数据库都不存在的数据,每次都要查数据库,缓存好像没有起到拦截流量作用。
- 缓存一致性:
- 更新mysql后,不管redis,由过期时间兜底
- 更新mysql后也写入redis,可能有时序性问题,更常用直接删除,下次再加载缓存
- 通过消息队列订阅mysql的binlog,实现缓存一致性,适用于缓存基本不过期时间的场景
缓存异常与一致性
背帆2024-02-09 8:41
相关推荐
池央4 分钟前
CANN Catlass 算子模板库深度解析:GEMM 核心优化、模板元编程与片上缓存策略的协同这周也會开心1 小时前
Redis数据类型的底层实现和数据持久化My LQS2 小时前
使用 Redis Stack 向量索引构建大模型问答缓存系统IT陈图图17 小时前
CANN生态数据引擎:minddata的缓存策略与性能调优啦啦啦_999920 小时前
Redis-2-queryFormat()方法forestsea1 天前
深入理解Redisson RLocalCachedMap:本地缓存过期策略全解析啦啦啦_99991 天前
Redis-0-业务逻辑自不量力的A同学1 天前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端fengxin_rou1 天前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿fengxin_rou1 天前
黑马点评实战篇|第二篇:商户查询缓存