缓存穿透(查不到):查询一个数据时Redis内存数据库没有,缓存未命中,于是向持久层数据库查询发现也不存在,查询失败。当多次缓存未命中时,都去请求持久层数据库造成压力,若用此进行攻击可能压垮数据库。
缓存击穿(查得到但量太大,或缓存过期):顾名思义就像子弹盯着一个点打最后在这个点把墙击穿一样,缓存击穿是缓存中可以查询到这个key,但高并发的持续查询这个key时,穿透了缓存直接请求到持久层数据库,瞬间压力而崩溃。比如热点数据过期的瞬间(60s),请求数据库回写缓存时(60.1s),这0.1s的大量请求瞬间压垮数据库,例微博热搜崩溃 。
缓存雪崩:指某一个时间内,缓存集中过期失效、Redis宕机、服务器重启、断电断网等缓存不可用的情况(Redis缓存崩溃了雪崩了)。然后所有请求直接打到后端数据库上,然后你懂的。
原创不易,请勿转载(
本不富裕的访问量雪上加霜) 博主首页:https://blog.csdn.net/qq_45034708