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

  1. 缓存击穿

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

  1. 缓存穿透

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

  1. 缓存雪崩

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

相关推荐
像我这样帅的人丶你还6 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩6 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia6 小时前
Mybatis的日志输入
java
亦暖筑序8 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户2986985301411 小时前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao11 小时前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿12 小时前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试
鹤望兰67512 小时前
字节跳动国际支付-后端开发-三面面经
java
Flittly12 小时前
【AgentScope Java新手村系列】(14)人机交互
java·spring boot·spring
RainCity12 小时前
Java Swing 自定义组件库分享(十二)
java·笔记·后端