缓存击穿
- 1、概念:
- 指的是大量访问某个key值时,key值本来存在于redis中(或者redis中没有但数据库中有该数据),但因为设置了key的有效期而使得redis中被访问的key失效,大量访问在redis中的不到反馈,则大量访问转移至数据库,导致数据库崩溃。
- 例子:
- 秒杀商品时,原本某商品预计秒杀时间为1小时,redis的key有效期也为1小时,但因某些原因,延长了秒杀过程而key值失效,使得缓存击穿,数据库崩溃。
- 2、解决方法:
- a、设置热点数据key永远不过期(定时更新热点数据)。
- b、加互斥锁:
- 在同一时间只能有一个线程访问数据库,并且访问完数据库,将数据缓存至redis
- 缺点:效率低
缓存穿透
- 1、概念:
- 指有大量访问redis中不存在的key值(或者redis中没有且数据库中也没有该数据),使得redis命中率为0,只能将大量访问转移至数据库,导致数据库崩溃。
- 一般属于黑客攻击,比如访问某个id为负值的数据。
- 2、解决方法:
- a、即使数据库中没有该数据,也缓存搜索的key到redis,值为null,key值有效期相对设置较短
- b、多为黑客攻击,封禁或者限制ip登录
- c、接口层增加校验,如用户鉴权校验,id做基础校验,id <= 0的直接拦截
缓存雪崩
- 1、概念
- 指redis中的大量key值相同时间失效,导致大量的访问转移至数据库,导致数据库崩溃。
- 2、解决方法:
- a、随机赋予key失效时间
- b、热点数据永不过期(根据实际更新热点数据)