真实面经题目 · 原创解析
什么是缓存穿透?
什么是缓存穿透?这道腾讯牛客题的关键是围绕“缓存穿透”讲清概念、机制、取舍和边界。缓存穿透指请求查询一个缓存和数据库都不存在的 key,缓存无法命中,每次都会打到数据库。恶意构造不存在参数或大量长尾不存在 key 时,会造成回源 QPS 异常升高。
真实面经题目 · 原创解析
什么是缓存穿透?这道腾讯牛客题的关键是围绕“缓存穿透”讲清概念、机制、取舍和边界。缓存穿透指请求查询一个缓存和数据库都不存在的 key,缓存无法命中,每次都会打到数据库。恶意构造不存在参数或大量长尾不存在 key 时,会造成回源 QPS 异常升高。
可以这样回答:缓存穿透指请求查询一个缓存和数据库都不存在的 key,缓存无法命中,每次都会打到数据库。恶意构造不存在参数或大量长尾不存在 key 时,会造成回源 QPS 异常升高。 常见治理是对不存在结果缓存空值并设置短 TTL,或者在缓存前加布隆过滤器拦截必不存在的 key;还要做参数校验、限流、黑名单和监控。 空值缓存简单但可能污染缓存,TTL 太长会影响新数据写入后的可见性;布隆过滤器内存低但有误判,且需要处理新增/删除同步。 要和缓存击穿、缓存雪崩区分。穿透是查不存在 key;击穿是热点 key 过期;雪崩是大量 key 同时失效或缓存整体故障。 验证时重点看:看不存在 key 比例、缓存命中率、DB QPS、空值缓存数量、布隆过滤器命中/误判和异常参数分布。
这题必须围绕“缓存穿透”本身回答,不能套相邻大类模板。先给定义或目标,再展开机制、边界、取舍和验证抓手。回答时要主动点出题面关键词对应的对象、输入输出和约束条件,避免把具体问题讲成宽泛复习提纲。 本题对应“缓存穿透”,核心前提是:缓存穿透指请求查询一个缓存和数据库都不存在的 key,缓存无法命中,每次都会打到数据库。恶意构造不存在参数或大量长尾不存在 key 时,会造成回源 QPS 异常升高。
常见治理是对不存在结果缓存空值并设置短 TTL,或者在缓存前加布隆过滤器拦截必不存在的 key;还要做参数校验、限流、黑名单和监控。 关键证据要落到命令执行路径、数据结构编码、事件循环、复制状态,这样才能说明机制为什么能支撑题目结论。如果继续展开,要把命令、底层编码、事件循环、过期或复制状态放到同一条 Redis 执行链路里解释。
空值缓存简单但可能污染缓存,TTL 太长会影响新数据写入后的可见性;布隆过滤器内存低但有误判,且需要处理新增/删除同步。 因此要同时看命令复杂度、内存占用、主线程阻塞、复制延迟和 failover 窗口,避免把 Redis 当成强一致数据库。 这些取舍决定了方案在不同输入规模、延迟、内存、并发、泛化或一致性要求下是否仍然成立。
要和缓存击穿、缓存雪崩区分。穿透是查不存在 key;击穿是热点 key 过期;雪崩是大量 key 同时失效或缓存整体故障。 排查时优先看 INFO、SLOWLOG、latency doctor、big key、hot key、过期统计、复制延迟和 failover 日志。 需要特别关注极端输入、数据分布变化、资源不足、并发竞争或观测口径错误带来的退化。修复时要先确认慢在命令、数据结构、网络、过期、持久化还是复制切换,再决定拆 key、限流、改结构或调整高可用。
验证时看 INFO、SLOWLOG、latency doctor、命令耗时、big key/hot key、expired_keys、evicted_keys、复制 offset/lag、Sentinel/Cluster 日志、AOF/RDB 配置和业务回源 QPS。 针对本题,最有价值的验证信号是:看不存在 key 比例、缓存命中率、DB QPS、空值缓存数量、布隆过滤器命中/误判和异常参数分布。把验证抓手说出来,可以让答案从知识点延伸到Redis 命令行为、延迟和故障窗口验证。
因为后续如果这个 key 被真实创建,过长 TTL 会让用户继续读到不存在结果,通常要短 TTL 或写入时主动删除空值缓存。
不能。它可能误判存在,而且数据新增、删除、重建都要同步过滤器;还需要限流和参数校验兜底。 回答时还要补充适用前提、失败场景和验证信号,避免只给一个孤立结论。
应该围绕“缓存穿透”补适用前提、失败场景和验证证据。先说明哪些条件下这个机制成立,再说明哪些输入规模、并发状态、数据分布或资源限制会让答案需要调整。
看它能否把“缓存穿透”的机制链路、关键取舍和可观测信号连起来。回答时应落到具体状态变化、数据路径、复杂度、指标或排查工具,而不是只复述定义。
数据结构看类型、底层编码、复杂度和内存;缓存看命中率、过期、穿透击穿雪崩和回源;高可用看复制延迟、Sentinel/Cluster、failover 和丢数据窗口。