-
缓存击穿
-
现象:恶意用户模拟请求很多缓存中不存在的数据,由于缓存中都没有,导致这些请求短时间内都直接落到了数据库上,导致数据库压力过大,崩掉
- 解决方案:
- 布隆过滤器: bloomfilter可以快速判断key是否存在于容器,不存在就直接返回
- 使用互斥锁队列: 根据key获取value值为空时,锁上,从数据库中load数据后在释放锁
-
-
缓存雪崩
- 缓存在同一时间内,大量key过期,接下来一大波请求瞬间都落在数据库中,导致数据库挂掉
- 建立备份缓存,缓存A和B,A设置超时,B不设置超时时间,先从A读缓存,A没有读B,并且更新A缓存和B缓存
- 使用互斥锁队列: 根据key获取value值为空时,锁上,从数据库中load数据后在释放锁
- 缓存在同一时间内,大量key过期,接下来一大波请求瞬间都落在数据库中,导致数据库挂掉