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

  1. 缓存击穿

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

  1. 缓存穿透

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

  1. 缓存雪崩

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

相关推荐
李坤林17 分钟前
Android Binder 详解(4) Binder 线程池
android·java·binder
代码方舟19 分钟前
Java后端实战:构建基于天远手机号码归属地核验的金融级风控模块
java·大数据·开发语言·金融
困知勉行198522 分钟前
springboot整合redis
java·spring boot·redis
颜淡慕潇26 分钟前
深度解析官方 Spring Boot 稳定版本及 JDK 配套策略
java·后端·架构
中年程序员一枚37 分钟前
Springboot报错Template not found For name “java/lang/Object_toString.sql
java·spring boot·python
知识分享小能手1 小时前
Ubuntu入门学习教程,从入门到精通,Ubuntu 22.04中的Java与Android开发环境 (20)
java·学习·ubuntu
南屿欣风1 小时前
FeignClient 踩坑:@FeignClient 同时配 value 和 url 的 “无效服务名” 问题
java
豆沙沙包?1 小时前
2026年--Lc329-735. 小行星碰撞(栈)--java版
java·开发语言
爆更小哇2 小时前
Selenium自动化测试函数全解析(二)
java·selenium·测试工具·自动化
C雨后彩虹2 小时前
计算误码率
java·数据结构·算法·华为·面试