redis缓存穿透,缓存雪崩

  1. 缓存击穿

    1. 现象:恶意用户模拟请求很多缓存中不存在的数据,由于缓存中都没有,导致这些请求短时间内都直接落到了数据库上,导致数据库压力过大,崩掉

    2. 解决方案:
      1. 布隆过滤器: bloomfilter可以快速判断key是否存在于容器,不存在就直接返回
      2. 使用互斥锁队列: 根据key获取value值为空时,锁上,从数据库中load数据后在释放锁
  2. 缓存雪崩

    1. 缓存在同一时间内,大量key过期,接下来一大波请求瞬间都落在数据库中,导致数据库挂掉
      1. 建立备份缓存,缓存A和B,A设置超时,B不设置超时时间,先从A读缓存,A没有读B,并且更新A缓存和B缓存
      2. 使用互斥锁队列: 根据key获取value值为空时,锁上,从数据库中load数据后在释放锁

 

你可能感兴趣的:(redis缓存穿透,缓存雪崩)