Redis(二)-----数据分区 : https://cloud.tencent.com/developer/article/1744809
Redis(三)-----集群方案 : https://cloud.tencent.com/developer/article/1744811
Redis(四)-----持久化 : https://cloud.tencent.com/developer/article/1744791
Redis(五)-----应用场景 : https://cloud.tencent.com/developer/article/1744816
Redis(六)-----缓存穿透/缓存雪崩/缓存击穿 : https://cloud.tencent.com/developer/article/1744796
Redis(七)—淘汰删除策略 : https://cloud.tencent.com/developer/article/1744827
缓存穿透:
缓存穿透,是指查询一个数据库一定不存在的数据。正常的使用缓存流程大致是,数据查询先进行缓存查询,如果key不存在或者key已经过期,再对数据库进行查询,并把查询到的对象,放进缓存。如果数据库查询对象为空,则不放进缓存。
。一些恶意的请求会故意查询不存在的key,请求量很大,就会对后端系统造成很大的压力。
如果传入一个在Redis和后端数据库都不存在的key,Redis和后端数据库都查找了一遍,且因为在后端数据库找不到,不会存到Redis中,那么,就导致一个恶意的请求,两个数据库都遍历一遍
如何避免?
缓存雪崩
当缓存服务器重启或者大量缓存集中在某一个时间段集中过期失效,这样在失效的时候,会给后端系统带来很大压力。导致系统崩溃。
例子
如何避免?
缓存击穿
缓存击穿,是指一个key非常热点,在不停的扛着大并发,大并发集中对这一个点进行访问,当这个key在失效的瞬间,持续的大并发就穿破缓存,直接请求数据库,就像在一个屏障上凿开了一个洞。
如何避免?