缓存雪崩缓存穿透与缓存击穿的区别

这三种的区别:
雪崩关键词是同一时间大批量数据失效
穿透关键字是非正常数据请求
击穿关键词是并发查询同一数据

缓存雪崩:大量缓存数据同时间失效,导致用户直接发起大量请求到数据库,产生瓶颈。
举例:双十一时某宝的访问量是非常大的,所以他的基本数据都是放在redis缓存起来,对应redis的一百个key,然后设置了缓存失效时间为三个小时,当购物时间超过这个失效时间时,这个网站的redis就会在一瞬间全部失效,导致所有请求都打在数据库上,造成这个数据库反应不过来然后直接挂掉,无法支持前端数据运行,这个情况就是缓存雪崩(大量redis缓存在同一时间全部失效)
解决方案:
1.(生成随机失效的缓存时间数据)在设置缓存的失效时间时随机初始化他的失效时间,避免所有缓存同一时间全部失效;
2.(让缓存节点分布在不同的物理节点上)redis一般是集群部署,我们可以把这些热点的key放在不同的节点上,让热点缓存平均的分布在不同的redis节点上;
3.(生成不失效的缓存数据)不设置缓存的失效时间,使缓存永不失效;
4.(定时任务更新缓存数据)定时的去刷新缓存,如某缓存写了三个小时的时效,在他三个小时失效之前,再把这个redis缓存重新跑入,然后再设置三小时,

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值