您现在的位置是:亿华云 > IT科技
这几道Redis面试题都不懂,怎么拿offer?
亿华云2025-10-09 11:08:36【IT科技】8人已围观
简介随着系统访问量的提高,复杂度的提升,响应性能成为一个重点的关注点。而缓存的使用成为一个重点。redis 作为缓存中间件的一个佼佼者,成为了面试必问项目。本文分享一下Redis几道常见的面试题:缓存雪崩
随着系统访问量的面试提高,复杂度的题都提升,响应性能成为一个重点的不懂关注点。而缓存的面试使用成为一个重点。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对于读操作,流程是这样的
如果我们的数据在缓存里边有,那么就直接取缓存的。
如果缓存里没有我们想要的数据,我们会先去查询数据库,b2b供应网然后将数据库查出来的数据写到缓存中。***将数据返回给请求。
3.2什么是缓存与数据库双写一致问题?
如果仅仅查询的话,缓存的数据和数据库的数据是没问题的。但是,当我们要更新时候呢?各种情况很可能就造成数据库和缓存的数据不一致了。
这里不一致指的是:数据库的数据跟缓存的数据不一致
从理论上说,只要我们设置了键的过期时间,我们就能保证缓存和数据库的数据最终是一致的。因为只要缓存数据过期了,就会被删除。随后读的时候,因为缓存里没有,就可以查数据库的数据,然后将数据库查出来的数据写入到缓存中。
除了设置过期时间,我们还需要做更多的措施来尽量避免数据库与缓存处于不一致的情况发生。
***
本文带领大家了解了如何解决缓存雪崩、缓存穿透、保证缓存与数据库双写时一致 等问题。除此之外还有很多提问点需要我们关注,推荐阅读列出一部分。
希望大家看完有所帮助。
很赞哦!(4581)
相关文章
- 当投资者经过第二阶段的认真学习之后又充满了信心,认为自己可以在市场上叱咤风云地大干一场了。但没想到“看花容易绣花难”,由于对理论知识不会灵活运用.从而失去灵活应变的本能,就经常会出现小赢大亏的局面,结果往往仍以失败告终。这使投资者很是困惑和痛苦,不知该如何办,甚至开始怀疑这个市场是不是不适合自己。在这种情况下,有的人选择了放弃,但有的意志坚定者则决定做最后的尝试。
- Flask-SocketIO 简单使用指南
- 用 Babel 和 Nodemon 搭建一个功能齐全的 Node.js 开发环境
- 五分钟菜鸟学会Python玩转SQL的神器!
- .com域名是国际最广泛流行的通用域名,目前全球注册量第一的域名,公司企业注册域名的首选。国际化公司通常会注册该类域名。
- Python进行数据可视化,你会用什么库来做呢?
- 几百行代码实现一个脚本解释器
- 聊聊Python中常见魔法方法
- 互联网中的地址是数字的IP地址,域名解析的作用主要就是为了便于记忆。
- Java开发的九大工作领域