redis缓存雪崩缓存穿透缓存击穿php(redis缓存雪崩和缓存击穿)

什么是redis缓存雪崩?

Redis缓存雪崩是指在某个时间段内,缓存集中过期失效,导致数据库负载急剧增加的现象,同时大量请求涌入数据库,造成数据库瓶颈甚至宕机。

如何避免缓存穿透?

缓存穿透指查询一个一定不存在的数据,由于缓存不命中,就会直接查数据库,而对于类似于恶意攻击的情况,缓存中没有该数据,但是这个请求仍旧会涌到数据库,导致数据库瞬间崩溃。如何避免缓存穿透呢?

一种常见的方法是采用布隆过滤器,通过把所有可能存在的数据哈希到一个足够大的bitmap中,进行查找操作之前,先判断key是否在bitmap中。

如何应对缓存击穿?

缓存击穿通常是指查询一个数据非常热点,如果这个热点key的缓存过期,同时在这个缓存过期的时刻,有大量的请求直接打到了数据库,造成了短时间内数据库瞬间崩溃的现象。如何应对缓存击穿呢?

第一种方案就是在key过期的时候,让这个key对应的数据不会过期,可以通过对缓存系统设计或者提供特别的API来实现;第二种方案是对热点数据进行加锁,当一个key在查询不到时,不是立即去请求数据库,而是先对这个key进行加锁,防止并发的请求同时进入数据库查询。

总结

在实际生产环境中,我们使用Redis做缓存时必须要考虑到异常情况的处理。Redis缓存雪崩、缓存穿透和缓存击穿都是缓存处理过程中的常见异常情况,处理方式不同,但是最终的目标是一样的,即尽可能的提高服务的可用性和稳定性,减少出现问题的概率。

本文来自投稿,不代表亲测学习网立场,如若转载,请注明出处:https://www.qince.net/dockeryh8.html

郑重声明:

本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,不存在任何商业目的与商业用途。 若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。

我们不承担任何技术及版权问题,且不对任何资源负法律责任。

如遇到资源无法下载,请点击这里失效报错。失效报错提交后记得查看你的留言信息,24小时之内反馈信息。

如有侵犯您的版权,请给我们私信,我们会尽快处理,并诚恳的向你道歉!

(0)
上一篇 2023年6月24日 下午2:07
下一篇 2023年6月24日 下午2:07

猜你喜欢