栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

缓存击穿、缓存穿透、缓存雪崩简单总结

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

缓存击穿、缓存穿透、缓存雪崩简单总结

缓存击穿
  • 1、概念:
    • 指的是大量访问某个key值时,key值本来存在于redis中(或者redis中没有但数据库中有该数据),但因为设置了key的有效期而使得redis中被访问的key失效,大量访问在redis中的不到反馈,则大量访问转移至数据库,导致数据库崩溃。
    • 例子:
      • 秒杀商品时,原本某商品预计秒杀时间为1小时,redis的key有效期也为1小时,但因某些原因,延长了秒杀过程而key值失效,使得缓存击穿,数据库崩溃。
  • 2、解决方法:
    • a、设置热点数据key永远不过期(定时更新热点数据)。
    • b、加互斥锁:
      • 在同一时间只能有一个线程访问数据库,并且访问完数据库,将数据缓存至redis
      • 缺点:效率低

缓存穿透
  • 1、概念:
    • 指有大量访问redis中不存在的key值(或者redis中没有且数据库中也没有该数据),使得redis命中率为0,只能将大量访问转移至数据库,导致数据库崩溃。
    • 一般属于黑客攻击,比如访问某个id为负值的数据。
  • 2、解决方法:
    • a、即使数据库中没有该数据,也缓存搜索的key到redis,值为null,key值有效期相对设置较短
    • b、多为黑客攻击,封禁或者限制ip登录
    • c、接口层增加校验,如用户鉴权校验,id做基础校验,id <= 0的直接拦截

缓存雪崩
  • 1、概念
    • 指redis中的大量key值相同时间失效,导致大量的访问转移至数据库,导致数据库崩溃。
  • 2、解决方法:
    • a、随机赋予key失效时间
    • b、热点数据永不过期(根据实际更新热点数据)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/631362.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号