redis缓存穿透和缓存雪崩

缓存穿透

原因:用户查询数据库中根本就没有的数据,缓存中自然也就没有,这样每次用户的查询都会去数据库查一次

解决办法:

  • 第一次从数据库没查到,则设置一个默认值在缓存,并返回默认值;这样后面的请求就不会再查数据库了

缓存雪崩

原因:大量缓存同一时间集中失效,导致所有的请求都跑去查数据库,导致数据库IO、内存、CPU压力过大,甚至系统崩溃
解决办法:

  • 对查数据库加锁(主要应对缓存并发问题)
  • 对缓存的更新放到队列中处理
  • 对缓存的过期时间加上一个随机数,让缓存过期时间均匀分布
  • 缓存永远不过期,意思是缓存不设置过期时间,但是在value中有一个过期时间字段;后台线程扫描到key即将过期的时候,重新构建缓存,如果发现数据库没查到,则删除缓存,避免数据不一致

猜你喜欢

转载自www.cnblogs.com/yinchh/p/10434355.html