- 缓存异常:
- 缓存穿透:请求缓存和数据库都不存在的数据,每次都要查数据库,缓存好像没有起到拦截流量作用。
- 采用布隆过滤器过滤一定不存在key请求、key逻辑校验,不存在key请求设置缓存key-null
- 布隆过滤器采用多个hash函数,若请求的key的多个hash值都存在,则可能存在,否则一定不存在
- 缓存击穿:缓存热key过期,导致大量请求打到数据库上
- 采用热key续期,重建缓存加互斥锁
- 缓存雪崩:大量缓存key过期,大量请求打到数据库
- 采用过期时间设置随机,防止同时大量缓存过期
- 缓存穿透:请求缓存和数据库都不存在的数据,每次都要查数据库,缓存好像没有起到拦截流量作用。
- 缓存一致性:
- 更新mysql后,不管redis,由过期时间兜底
- 更新mysql后也写入redis,可能有时序性问题,更常用直接删除,下次再加载缓存
- 通过消息队列订阅mysql的binlog,实现缓存一致性,适用于缓存基本不过期时间的场景
缓存异常与一致性
背帆2024-02-09 8:41
相关推荐
Saniffer_SH8 小时前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境AC赳赳老秦11 小时前
OpenClaw + 飞书多维表格:自动同步数据、生成统计图表、触发自动化任务阿猫的故乡12 小时前
Vue动态组件+异步组件实战:Tab切换、按需加载、KeepAlive缓存,一次搞定uoKent13 小时前
Redis环境搭建与redis-cli基础操作啾啾Fun14 小时前
【LLM 应用优化】Prompt Caching:LLM 调用成本降 90% 的底层机制与实战策略IT策士1 天前
Redis 从入门到精通:性能调优与多语言客户端对比IronMurphy1 天前
【算法五十七】146. LRU 缓存伊甸31 天前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战摇滚侠1 天前
MyBatis 入门到项目实战 MyBatis 的缓存 56-61IT策士1 天前
Redis 从入门到精通:Redis Stream —— 可靠消息队列