缓存穿透和雪崩

缓存穿透:中小型的传统科技公司可能不需要考虑这个问题,但是当数据量非常大的时候那么我们需要解决这个问题

为什么会产生缓存穿透? 当黑客不断的去请求缓存中不存在的数据,所以就会导致大量的请求直接怼向数据库,这个时候数据库就会出现链接异常的问题,甚至直接崩溃。

如何解决缓存穿透问题? 1.加上互斥锁  当缓存失效的时候 先去获取锁,等拿到锁之后再去请求数据库 这样有序的去请求数据库就可以避免,如果没有拿到锁 就进行休眠,一直到那拿到锁为止。

2.异步更新策略 在取key值的时候无论是否取到key 都直接返回value值,设置value缓存,如果缓存失效那么就会重新起一个线程去重新读取数据库方法放到缓存中。

3.去部署一个迅速拦截机制 主要就是判断key值是否合法 如果不合法那么就直接返回。

 

为什么会产生缓存雪崩? 当缓存大面积失效,那么一大波请求就会直接怼向数据库,造成数据库出现链接异常

如何解决缓存雪崩? 1.给缓存设置失效时间 加上随机量 避免全部失效

2.双缓存 A缓存设置失效时间 B不设置失效时间 ,从缓存A中读取数据如果没有就直接读取缓存B,直接返回 此时重新启动一个新的线程去读取数据库 然后去更新缓存A,B

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值