Redisi缓存的击穿、穿透、雪崩,介绍一下

  1. 缓存击穿

缓存击穿是指在高并发场景下,缓存中的某个 key 失效,此时大量请求同时涌入数据库查询该 key 的数据,导致数据库瞬间压力过大,甚至宕机。缓存击穿的最佳解决方案是使用互斥锁,令只有一个线程可以从数据库中查询出数据,其他线程等待。同时也可以在缓存中设置短期的过期时间,确保缓存在短时间内得到更新。

  1. 缓存穿透

缓存穿透是指在高并发场景下,请求的 key 在缓存和数据库中都没有对应的数据,导致大量请求直接落到数据库上,导致数据库瞬间压力过大,甚至宕机。缓存穿透的解决方案包括使用布隆过滤器对请求进行过滤,将不存在的 key 直接拦截掉;或者设置空值缓存,将请求不存在的 key 在缓存中也做出对应的响应,避免访问数据库。

  1. 缓存雪崩

缓存雪崩是指在某一时刻,缓存中大量的 key 同时失效,导致大量的请求同时涌入数据库,导致数据库瞬间压力过大,甚至宕机。防止缓存雪崩的方法包括使用分布式锁,令缓存失效的过程不会同时发生,同时可以在缓存中设置过期时间的随机偏移量,避免大量缓存同时失效。

相关推荐
Mahir087 分钟前
ConcurrentHashMap 底层原理深度解密:从分段锁到 CAS + 红黑树的演进全解
java·面试·concurhashmap
阿维的博客日记10 分钟前
那用到动态代理,关键的特征又是什么呢
java·动态代理
都说名字长不会被发现13 分钟前
Spring Boot Starter 中间件账号密码加密方案设计与实现
java·spring boot·后端·中间件
摇滚侠13 分钟前
Maven 依赖范围
java·maven
AKA__Zas14 分钟前
芝士算法(滑动窗口片 2.0)
java·算法·leetcode·学习方法
Zella折耳根2 小时前
复习篇-常用实用类
java
devilnumber8 小时前
Java 递归算法 详解 + 核心要点 + 实战运用 + 避坑指南
java·开发语言·算法
asdfg125896310 小时前
JavaBean是什么?怎么理解?有什么用途?
java·开发语言
摇滚侠11 小时前
SpringMVC 入门到实战 文件上传 75-77
java·后端·spring·maven·intellij-idea
GIS数据转换器11 小时前
城市排水生命线安全运行监测平台深度解析
java·运维·人工智能·python·安全·数据挖掘·无人机