您现在的位置是:亿华云 > 数据库
面试被吊打系列-Redis缓存血崩
亿华云2025-10-04 03:55:18【数据库】7人已围观
简介本文转载自微信公众号「JAVA日知录」,作者单一色调。转载本文请联系JAVA日知录公众号。小张兴冲冲去面试,结果因为redis的缓存雪崩问题被面试官拒绝!小张:面试官,你好。我是来参加面试的。面试官:
本文转载自微信公众号「JAVA日知录」,面试作者单一色调。被吊转载本文请联系JAVA日知录公众号。打系
小张兴冲冲去面试,缓存结果因为redis的血崩缓存雪崩问题被面试官拒绝!
小张:面试官,你好。面试我是被吊来参加面试的。
面试官:你好,打系小张。缓存我看了你的血崩简历,你们平时在项目中用了redis,面试能说一下你们使用redis的被吊场景吗?
小张:redis的话我们主要是用来存储一些常用的配置类数据还有一些热点数据;还有存储一些到期失效的数据,比如登录用户颁发的打系token等。
面试官:那好,缓存既然你们用来存储热点数据。血崩那么我来问你个实际场景,「查询热点数据的时候会先从缓存加载,如果缓存没有命中则会检索数据库获取数据。往往我们还会给热点缓存数据设置一个过期时间。那么我的源码下载问题是,假设在某一时间点热点缓存全部过期失效了,这样所有的请求都会直接进入数据库,一瞬间就会把数据库压垮,如果是你会怎么解决这个问题?」
小张:emm...面试官,我肚子有点不舒服,我先回去了。小张卒!
面试官:因为缓存同一时间大面积的失效,或者缓存服务暂时不能提供服务等,从而导致所有请求都去查数据库,导致数据库CPU和内存负载过高,甚至宕机。这一现象被称之为 「缓存雪崩」。
缓存血崩可以通过以下四个维度来解决:
「缓存预热」
数据加热的含义就是在正式部署之前,先把可能的数据先预先访问一遍,这样部分可能大量访问的数据就会加载到缓存中。在即将发生大并发访问前手动触发加载缓存不同的key。
「加上互斥锁」
可以在第一个查询数据的请求上使用一个互斥锁来锁住它,其他的线程走到这一步拿不到锁就等着,香港云服务器等第一个线程查询到了数据,然后将数据放到redis缓存起来。后面的线程进来发现已经有缓存了,就直接走缓存。
「过期时间均匀分布」
给缓存的时效时间加上随机因子,即给缓存设置不同的过期时间,让缓存失效的时间点尽量均匀。
「构建高可用的缓存系统」
把Redis设计成高可用的,即使个别节点、个别机器、甚至是机房宕掉,依然可以提供服务,例如 Redis Sentinel 和 Redis Cluster 都实现了高可用。
面试官:各位看官朋友们,你们学会怎么解决缓存雪崩的问题了吗?希望你们以后面试不会被这个问题难倒哟~
小张:学到了学到了,我下次再来。(早知道不提什么热点数据了,不提面试官就不会问。)
面试官:小样,不问这个那么我不会问其他的了吗?你下次再来试试!
很赞哦!(76782)
下一篇: ④注册门槛低
相关文章
- 投资各类域名就像到处打游击战,结果处处失败。因为这样,对任何一个中国域名市场的走势和价格都没有准确的把握,所以最好缩小范围,准确把握战场态势,埋伏。
- 什么是绿色数据中心?
- 什么是电源使用效率 (PUE),它是如何计算的?
- 面试官再跟你说中国没有根服务器,雪人计划让他了解下
- 审核通过的域名将显示在域名竞拍页面,并进入正式拍卖期,买家可以在拍卖周期内出价,加价幅度与拍卖保证金说明,点此查看。
- vivo 自研Jenkins资源调度系统设计与实践
- 七个常见数据中心迁移挑战
- 打造智算中心新标杆,普洛斯数据中心荣获“2023年数据中心科技成果奖”一等奖
- 5. 四种状态过后,域名管理机构释放域名给公众注册。
- 专家视点:减少数据中心的碳足迹