redis的缓存雪崩如何解决和预防

什么是雪崩?

首先redis的作用就是在数据访问层在访问数据库的时候,通过一种缓存的手段,去实现通过内存读取数据,在请求数据的时候,首先会在redis中查找,如果redis没有再去数据库中查找,再将查到的数据返回并保存在redis中,之后的查询都会从redis中查


而雪崩就是说如果redis中的数据消失,导致同一时间有一堆请求同时进入数据库,导致数据库崩溃


造成雪崩的常见的场景有:

  1. 当redis的key同时失效,导致请求全部涌入数据库。
  2. redis服务重启导致所有数据丢失。
  3. redsis很稳定,但是如果外在因素导致redis服务关闭,那么也会导致雪崩
  4. 常用的key突然被删除或者失效

雪崩造成的影响:

  1. redis响应是十分快的,当redis出现雪崩会导致所有请求都进入数据库,导致数据库卡顿,本来几毫秒一瞬间就能完成的事情,现在需要几秒甚至更久,体验感非常差
  2. 数据库本来靠着缓存作为缓冲区,如果这个缓存区突然失效,就会导致所有的请求全部涌入数据库,就和三峡大坝一样,靠着三峡大坝来缓冲,拦截水流,如果三峡大坝出现问题,那么可能会导致所有的水,直接将我们淹没

如何预防和解决?

  1. 可以通过随机数设置不同的失效时间
  2. 定期备份数据进行持久化操作
  3. 通过加锁控制访问的数量
相关推荐
huangdong_7 小时前
电商平台图片URL原图转换技术深度解析:从缩略图到高清原图的完整方案
java·后端·spring
不能只会打代码9 小时前
边缘视频分析平台的架构设计与性能优化——从750ms到190ms的调优之路
java·spring boot·redis·性能优化·边缘计算·物联网竞赛
二哈赛车手10 小时前
新人笔记---最终版智能体图片分析完整方案,包括一些总结于经验,以及各种优化点讲解
java·笔记·spring·ai·springboot
泡^泡10 小时前
Spring AI简单高仿DeepSeek问答页面
java·人工智能·spring
xufengzhu12 小时前
第三方 Python 库 redis-py + hiredis 的使用
开发语言·redis·python
云烟成雨TD13 小时前
Spring AI 1.x 系列【61】Spring AI 2.0 升级指南
java·人工智能·spring
轻刀快马15 小时前
跨越软硬件的共鸣(二):从 Cache 写策略看 Redis 与 DB 的一致性博弈
java·开发语言·redis·计算机组成原理
A.说学逗唱的Coke15 小时前
【大模型专题】Spring AI Alibaba × Skill 整合实战:让 AI 真正“会干活
java·人工智能·spring
砍材农夫16 小时前
物联网实战|Spring Boot + Netty 搭建 MQTT 消息路由与流转层
java·spring boot·后端·物联网·spring
swordbob16 小时前
3 大 I/O 模型BIO / NIO / AIO
java·linux·spring