> 日常维修
如何防止edis缓存穿透(如何防止edis的key冲突)
导语:高频面试题-如何避免Redis中缓存穿透、缓存雪崩问题?
Redis,因为其速度快等各方面的原因,被开发人员一直应用于企业级开发。
而一旦开始使用Redis,就必然要考虑的问题就当属缓存穿透、缓存雪崩的问题了,这也是面试过程中很容易问到的点了,下面我们就来聊一下这些吧。
1. 什么是缓存穿透?缓存穿透是指当查询一个不存在的数据,由于无法命中对应的值,就会一直需要去数据库中查询;所以这个时候Redis并没有起到减少查询的次数,失去了使用Redis的初心,反而性能方面有了更大的消耗,就会造成整体的性能下降。
2. 如何解决缓存穿透问题?一句话答案:给没有命中的key值设置‘空值’。
虽然无法命中对应的值,但是我们依然要给对应的key设置空值。
这样,我们就又可以降低直接访问数据库的次数,从而一定程度上提高了系统性能。
3. 什么是缓存雪崩?雪崩时,没有一片雪花是无辜的。复制代码
缓存雪崩是指当一批缓存数据均设置了相同的过期时间时,会导致一批缓存数据同一时间失效,届时就会存在大批的请求同时去访问数据库,会造成数据库的瞬时压力过大,造成雪崩。
4. 如何解决缓存雪崩问题?一句话答案:给缓存数据的key设置不同的过期时间
缓存雪崩问题就是同一时间缓存过期问题,所以只需要给缓存数据设置不同的过期时间即可。
由于系统内部业务的限制,可以在某一个区间内取随机值,如:30分钟-60分钟之间的任意值;这样即便会存在相同过期时间,也不会很多。
当然了,如果你系统业务缓存量级比较大,加大区间就可以了。
本文内容由小楠整理编辑!