什么是雪崩?
首先redis的作用就是在数据访问层在访问数据库的时候,通过一种缓存的手段,去实现通过内存读取数据,在请求数据的时候,首先会在redis中查找,如果redis没有再去数据库中查找,再将查到的数据返回并保存在redis中,之后的查询都会从redis中查
而雪崩就是说如果redis中的数据消失,导致同一时间有一堆请求同时进入数据库,导致数据库崩溃
造成雪崩的常见的场景有:
- 当redis的key同时失效,导致请求全部涌入数据库。
- redis服务重启导致所有数据丢失。
- redsis很稳定,但是如果外在因素导致redis服务关闭,那么也会导致雪崩
- 常用的key突然被删除或者失效
雪崩造成的影响:
- redis响应是十分快的,当redis出现雪崩会导致所有请求都进入数据库,导致数据库卡顿,本来几毫秒一瞬间就能完成的事情,现在需要几秒甚至更久,体验感非常差
- 数据库本来靠着缓存作为缓冲区,如果这个缓存区突然失效,就会导致所有的请求全部涌入数据库,就和三峡大坝一样,靠着三峡大坝来缓冲,拦截水流,如果三峡大坝出现问题,那么可能会导致所有的水,直接将我们淹没
如何预防和解决?
- 可以通过随机数设置不同的失效时间
- 定期备份数据进行持久化操作
- 通过加锁控制访问的数量
redis的缓存雪崩如何解决和预防
小汤猿人类2024-10-28 16:26
相关推荐
小江的记录本1 天前
【JVM虚拟机】垃圾回收GC:四种引用类型:强引用、软引用、弱引用、虚引用(附《思维导图》+《面试高频考点清单》)小马爱打代码1 天前
Spring源码 第四篇:Spring 5 源码深度拆解:AOP 全流程核心原理RyFit1 天前
Java + AI 实战:Spring AI 从入门到企业级落地洛水水1 天前
Redis 分布式锁详解:实现与缺陷java1234_小锋1 天前
在 Spring AI 中如何实现函数调用(Function Calling)?请说明其基本原理和应用场景。小马爱打代码1 天前
Spring源码 第九篇:Spring 5 源码深度拆解 - Spring 事件驱动模型tongluowan0071 天前
Redisson的参数及工作原理云烟成雨TD1 天前
Spring AI Alibaba 1.x 系列【60】检查点机制原理与全流程剖析小马爱打代码1 天前
Spring源码 第十篇:Spring 5 源码深度拆解 - Spring 类型转换与校验体系2301_780789661 天前
高防cdn如何缓存网页静态资源