什么是缓存击穿?
大量缓存数据在同一时间过期(失效)或者 Redis 发生故障宕机时,如果此时有大量的用户请求,都无法在 Redis 中处理,于是全部请求都直接访问数据库,从而导致数据库的压力骤增,严重的会造成数据库宕机,从而形成一系列连锁反应,造成整个系统崩溃。(大量数据同时过期,Redis 故障宕机)
解决办法:
均匀设置过期时间;(我们可以在对缓存数据设置过期时间时,给这些数据的过期时间加上一个随机数,这样就保证数据不会在同一时间过期。)
双 key 策略;(主 key,会设置过期时间,一个是备 key,不会设置过期)
后台更新缓存;
构建 Redis 缓存集群
什么是缓存击穿?
缓存击穿是某个热点的key失效,大量请求集中对其进行请求,就会造成大量请求读redis缓存没读到数据,从而导致高并发访问mysql数据库,引起数据库压力剧增。这种现象就叫做缓存击穿。
解决办法:
采用互斥锁方案,保证同一时间只有一个业务线程更新缓存,未能获取互斥锁的请求,要么等待锁释放后重新读取缓存,要么就返回空值或者默认值。
不给热点数据设置过期时间
由后台异步更新缓存,在热点数据准备要过期前,提前通知后台线程更新缓存以及重新设置过期时间;
什么是缓存击穿?
缓存击穿是某个热点的key失效,大量请求集中对其进行请求,就会造成大量请求读redis缓存没读到数据,从而导致高并发访问mysql数据库,引起数据库压力剧增。这种现象就叫做缓存击穿。
解决办法:
采用互斥锁方案,保证同一时间只有一个业务线程更新缓存,未能获取互斥锁的请求,要么等待锁释放后重新读取缓存,要么就返回空值或者默认值。
不给热点数据设置过期时间
由后台异步更新缓存,在热点数据准备要过期前,提前通知后台线程更新缓存以及重新设置过期时间;
什么是缓存穿透?
当用户访问的数据,既不在缓存中,也不在数据库中,导致请求在访问缓存时,发现缓存缺失,再去访问数据库时,发现数据库中也没有要访问的数据,没办法构建缓存数据,来服务后续的请求。那么当有大量这样的请求到来时,数据库的压力骤增,这就是缓存穿透的问题。
缓存穿透的发生的一半情况
业务误操作,缓存中的数据和数据库中的数据都被误删除了,所以导致缓存和数据库中都没有数据;
黑客恶意攻击,故意大量访问某些读取不存在数据的业务;
应对缓存穿透的方案,常见的方案有三种。
解决方案:
第一种方案,非法请求的限制;
第二种方案,缓存空值或者默认值;
第三种方案,使用布隆过滤器快速判断数据是否存在,避免通过查询数据库来判断数据是否存在;
参考资料:
https://xiaolincoding.com/redis/cluster/cache_problem.html