缓存击穿
单个key过期的时候有大量并发.
1)使用互斥锁,回写redis
缓存雪崩
缓存雪崩就是Redis的大量热点数据同时过期(失效),因为设置了相同的过期时间,刚好这个时候Redis请求的并发量又很大,就会导致所有的请求落到数据库。
- 加互斥锁或者使用队列,针对同一个key只允许一个线程到数据库查询
2)缓存定时预先更新,避免同时失效
3)通过加随机数,使key在不同的时间过期
缓存穿透
缓存穿透是指缓存和数据库中都没有的数据,但是用户一直请求不存在的数据!这时的用户很可能就是攻击者,恶意搞你们公司的,攻击会导致数据库压力过大。
1)布隆过滤器,位图里面只有0跟1,然后将访问的值通过多个不同的hash算法得到不同的值,放置在不同的位图标记为1 有误判,没法判断数据一定存在,但是能判断一定不存在!
2)封IP