大家有更好的理解和见解可以批评指正下哦🤓🤓
1. 什么是缓存穿透,怎么解决
缓存穿透:查询一个不存在的数据,mysql查询不到数据也不会直接写入缓存,就会导致每次请求都查数据库。
解决方案一:缓存空数据
解决方案二:布隆过滤器
2. 什么是缓存击穿,怎么解决
缓存击穿:给某一个key设置了过期时间,当key过期的时候,恰好这时间点对这个key有大量的并发请求过来,这些并发的请求可能会瞬间把DB压垮
①解决方案一:用互斥锁:当缓存失效时,不立即去访问数据库,先使用如Redis的sentnx方法去设置一个互斥锁,当操作成功返回时再进行访问数据库的操作并回设缓存,否则重试get缓存的方法
②解决方案二:在设置key的时候,设置一个过期时间字段一块存入暖存中,不给当前key设置过期时间。查询的时候,从redis取出数据后判断时间是否过期,如果过期则开通另外一个践程进行数据同步,当前线程正常返回数据,这个数据不是最新的。
3.什么是缓存雪崩,怎么解决
缓存雪崩:是指在同一时段大量的缓存key同时失效(设置了相同的过期时间)或者Redis服务宕机,导致大量请求到达数据库,带来巨大压力。与缓存击穿的区别:雪崩是很多key,击穿是某一个key缓存
解决方案:
1.给不同的Key的TTL添加随机值
2.利用Redis集群提高服务的可用性
3.给缓存业务添加降级限流策略,降级可做为系统的保底策略,适用于穿透,击穿,雪崩
4.给业务添加多级缓存
1079

被折叠的 条评论
为什么被折叠?



