缓存击穿,缓存穿透,缓存雪崩的原因和解决方案?

缓存穿透

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

解决方案:

  • 接口层增加校验,如用户鉴权校验,id做基础校验,id<=0的直接拦截;
  • 从缓存取不到的数据,在数据库中也没有取到,这时也可以将key-value对写为key-null,缓存有 效时间可以设置短点,如30秒(设置太长会导致正常情况也没法使用)。这样可以防止攻击用户 反复用同一个id暴力攻击
  • 采用布隆过滤器,将所有可能存在的数据哈希到一个足够大的 bitmap 中

缓存击穿

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

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

缓存雪崩

缓存雪崩是指缓存同一时间大面积的失效,所以,后面的请求都会落到数据库上,造成数据库短时间内 承受大量请求而崩掉。

解决方案:

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

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-16 17:48:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-16 17:48:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-16 17:48:05       82 阅读
  4. Python语言-面向对象

    2024-01-16 17:48:05       91 阅读

热门阅读

  1. centos上怎么安装git

    2024-01-16 17:48:05       49 阅读
  2. 特殊后缀记录(.ftl,)

    2024-01-16 17:48:05       53 阅读
  3. Kotlin中的委托

    2024-01-16 17:48:05       52 阅读
  4. 列表进入详情页的传参问题(vue的问题)

    2024-01-16 17:48:05       49 阅读
  5. Stable Diffusion 提示词解析|AI绘画

    2024-01-16 17:48:05       54 阅读
  6. 中国泡菜市场供需与投资预测研究报告(2024版)

    2024-01-16 17:48:05       48 阅读
  7. SSL弱加密算法的漏洞研究

    2024-01-16 17:48:05       55 阅读
  8. 开发安全之:Insecure Transport: Weak SSL Protocol

    2024-01-16 17:48:05       49 阅读
  9. python3导入sql文件

    2024-01-16 17:48:05       50 阅读
  10. HTTP基本概念

    2024-01-16 17:48:05       61 阅读