• 如何避免缓存穿透、缓存击穿、缓存雪崩?


    缓存雪崩:

    缓存雪崩是指 缓存同⼀时间⼤⾯积的失效 ,所以,后⾯的请求都会落到 数据库 上, 造成数据库短时间内承受⼤量请求⽽崩掉

    解决方案:

    • 缓存数据的过期时间设置随机,防⽌同⼀时间⼤量数据过期现象发⽣。
    • 给每⼀个缓存数据增加相应的 缓存标记 ,记录缓存是否失效,如果缓存标记失效,则更新数据缓存。
    • 缓存预热互斥锁

    缓存穿透

    缓存穿透是指缓存和数据库中都没有的数据导致所有的请求都落到数据库上,造成数据库短时间内承受⼤量请求⽽崩掉。

    解决方案:

    • 接⼝层增加校验,如⽤户鉴权校验,id做基础校验,id<=0的直接拦截
    • 从缓存取不到的数据,在数据库中也没有取到,这时也可以将key-value对写为key-null,缓存有效时间可以设置短点,如30 秒(设置太⻓会导致正常情况也没法使⽤)。这样可以 防⽌攻击⽤户反复⽤同⼀个id暴⼒攻击
    • 采⽤ 布隆过滤器 ,将所有可能存在的数据哈希到⼀个⾜够⼤的 bitmap 中,⼀个⼀定不存在的数据会被这个 bitmap 拦截掉,从⽽ 避免了对底层存储系统的查询压⼒

    缓存击穿:

    缓存击穿是指 缓存中没有但数据库中有的数据 (⼀般是缓存时间到期),这时由于 并发⽤户特别多 同时读缓存没读到数据,⼜同时去数据库去取数据,引起数据库压⼒瞬间增⼤,造成 过⼤压⼒ 。和缓存雪崩不同的是,缓存击穿指并发查同⼀条数据,缓存雪崩是不同数据都过期了,很多数据都查不到从⽽查数据库。

    解决方案:

    • 设置热点数据永远不过期。加互斥锁

     

  • 相关阅读:
    Spring 整合嵌入式 Tomcat 容器
    AI技术在软件测试中的应用和实践
    JAVA毕业设计空闲教室查询系统计算机源码+lw文档+系统+调试部署+数据库
    iframe 跨域通信和不跨域通信
    w字符编码
    Unity3d的海盗王地图
    Typora和基本的Markdown语法
    SQL-DML数据操纵语言(Oracle)
    人体调优不完全指南「GitHub 热点速览 v.22.22」
    【面试高频题】难度 1/5,经典树的搜索(多语言)
  • 原文地址:https://blog.csdn.net/m0_70734549/article/details/127958269