这几道Redis面试题都不懂,怎么拿offer?
随着系统访问量的面试提高,复杂度的题都提升,响应性能成为一个重点的不懂关注点。而缓存的面试使用成为一个重点。redis 作为缓存中间件的题都一个佼佼者,成为了面试必问项目。不懂本文分享一下Redis几道常见的面试面试题:
缓存雪崩
1.1什么是缓存雪崩?
如果我们的缓存挂掉了,这意味着我们的题都全部请求都跑去数据库了。
我们都知道Redis不可能把所有的不懂数据都缓存起来(内存昂贵且有限),所以Redis需要对数据设置过期时间,面试并采用的题都是惰性删除+定期删除两种策略对过期键删除。
如果缓存数据设置的不懂过期时间是相同的,并且Redis恰好将这部分数据全部删光了。面试这就会导致在这段时间内,题都这些缓存同时失效,不懂全部请求到数据库中。
这就是缓存雪崩:Redis挂掉了,请求全部走数据库。高防服务器
缓存雪崩如果发生了,很可能就把我们的数据库搞垮,导致整个服务瘫痪!
1.2如何解决缓存雪崩?
在缓存的时候给过期时间加上一个随机值,这样就会大幅度的减少缓存在同一时间过期。
对于“Redis挂掉了,请求全部走数据库”这种情况,我们可以有以下的思路:
事发前:实现Redis的高可用(主从架构+Sentinel 或者Redis Cluster),尽量避免Redis挂掉这种情况发生。
事发中:万一Redis真的挂了,我们可以设置本地缓存(ehcache)+限流(hystrix),尽量避免我们的数据库被干掉(起码能保证我们的服务还是能正常工作的)
事发后:redis持久化,重启后自动从磁盘上加载数据,快速恢复缓存数据。
缓存穿透
2.1什么是缓存穿透
缓存穿透是指查询一个一定不存在的数据。由于缓存不***,并且出于容错考虑,如果从数据库查不到数据则不写入缓存,这将导致这个不存在的数据每次请求都要到数据库去查询,失去了缓存的站群服务器意义。
这就是缓存穿透:
请求的数据在缓存大量不***,导致请求走数据库。
缓存穿透如果发生了,也可能把我们的数据库搞垮,导致整个服务瘫痪!
2.1如何解决缓存穿透?
解决缓存穿透也有两种方案:
由于请求的参数是不合法的(每次都请求不存在的参数),于是我们可以使用布隆过滤器(BloomFilter)或者压缩filter提前拦截,不合法就不让这个请求到数据库层!
当我们从数据库找不到的时候,我们也将这个空对象设置到缓存里边去。下次再请求的时候,就可以从缓存里边获取了。
这种情况我们一般会将空对象设置一个较短的过期时间。
缓存与数据库双写一致
3.1对于读操作,流程是这样的
如果我们的数据在缓存里边有,那么就直接取缓存的。
如果缓存里没有我们想要的数据,我们会先去查询数据库,亿华云然后将数据库查出来的数据写到缓存中。***将数据返回给请求。
3.2什么是缓存与数据库双写一致问题?
如果仅仅查询的话,缓存的数据和数据库的数据是没问题的。但是,当我们要更新时候呢?各种情况很可能就造成数据库和缓存的数据不一致了。
这里不一致指的是:数据库的数据跟缓存的数据不一致
从理论上说,只要我们设置了键的过期时间,我们就能保证缓存和数据库的数据最终是一致的。因为只要缓存数据过期了,就会被删除。随后读的时候,因为缓存里没有,就可以查数据库的数据,然后将数据库查出来的数据写入到缓存中。
除了设置过期时间,我们还需要做更多的措施来尽量避免数据库与缓存处于不一致的情况发生。
***
本文带领大家了解了如何解决缓存雪崩、缓存穿透、保证缓存与数据库双写时一致 等问题。除此之外还有很多提问点需要我们关注,推荐阅读列出一部分。
希望大家看完有所帮助。
相关文章
- 1,安装linux复制代码代码如下: 然后是jdk: 复制代码代码如下: 复制代码代码如下: 这个命令之后需要多按几次回车,知道再次出现命令提示符。当然,这个做法也不是很安全,里面有个输入key的地方2025-11-05

Confluence服务器被黑客部署AvosLocker、Cerber2021勒索软件
近期,勒索软件团伙瞄准了一个远程代码执行 (RCE) 漏洞,该漏洞影响会Atlassian Confluence服务器和数据中心。如果成功利用此OGNL注入漏洞 (CVE-2022-26134),未经2025-11-05
研究人员发现,窃取信息的Android恶意软件Sharkbot通过防病毒解决方案的掩护悄悄地潜藏在Google Play商店的深处,给用户带来了极大的危险。事件起源于Check Point Resea2025-11-05
数据管理备份解决方案提供商Veeam Software公司日前发布的调查报告指出,网络犯罪分子成功加密了约47%的生产数据,而受害者却只能恢复69%的受影响数据。这份报告包含了这家研究机构对1000名2025-11-05- 摘要:在如今数字化的时代,手提电脑已经成为我们生活和工作中不可或缺的一部分。而正确的开机方式能够保证我们的电脑能够正常运行,并且延长其寿命。本文将详细介绍联想手提电脑的开机教程,让您轻松...2025-11-05
- 复制SELECT* FROMOPENROWSET(sqloledb, DRIVER={SQLServer};SERVER=127.0.0.1;UID=s2025-11-05

最新评论