redis的雪崩
原因
大量请求突然因为缓存层的失效而进入了MySQL,导致MySQL数据库的崩溃
案例
本来你的redis缓存层在请求高峰期的时候可以抗下几千个请求,但是突然有一天你的redis服务器宕机或者redis出现问题,这时候缓存层的突然失效,导致了大量的请求进入mysql,从而导致了MySQL服务器的崩溃,想要重启,但因为缓存层的失效,启动了也会被新的流量打死
解决方案
1,配置redis的主从+哨兵
2,可以对数据的请求进行限流
3,本地ehcache 缓存
4,redis的持久化,重启可以快速在磁盘中读取数据
redis的穿透
原因
前端的请求的都是在请求不存在的数据,导致缓存层查不到,然后请求到了MySQL,导致MySQL再次的分崩离析
案例
假如还是那个服务器,相同的服务器上,恶意人员请求的大量不存在的数据,就会绕过缓存层直接访问到数据库,因为这些都是不存在的数据请求,所有MYSQL将再次崩溃
解决方案
只要请求到一个不存在的数据,就写一个控制到缓存层去 ,然后下次这种请求过来后
就直接去缓存层访问那个空值
redis的击穿
前端访问缓存层的一个key非常的频繁,但是如果当key突然失效,就会请求MySQL,导致MySQL崩溃
解决方案
设置该key的的过期时间为永久不过期