如何防止缓存击穿和穿透

首先我们要明白缓存在一定意义上提高了系统的效率,降低了后台服务的压力,在系统并发量大的情况下,极大地提高了数据的查询性能,如redis的查询性能可高达110000次/秒

下面主要有几种防止的方法,归纳如下:

  1. 对于热点数据不设置key过期时间或进行延期
  2. 对于访问量大的数据可设置多级缓存
  3. 可以利用布隆过滤器,防止恶意攻击不存在key造成缓存击穿,应用启动后将数据缓存到布隆过滤器中
  4. 我们可以设置分布式锁,当发现缓存失效时,并不会直接到数据库中查找数据,而是先获取分布式锁,由获取分布式锁的线程到数据库中查询并存放到缓存中
  • 造成缓存击穿的原因大致有两点:
  1. 当缓存中的key失效的瞬间,有大量的key请求过来,直接打到数据库上
  2. 存在大量而已请求去访问不存在的key,导致缓存形同虚设。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值