给 Cassandra 前面加 Redis 做 cache-aside,为什么可能让计数更不准?
Why can adding Redis in front of Cassandra with a cache-aside pattern make the counter less accurate?
题目类型: 技术面试题
这是一道技术面试题,常见于澳洲IT公司面试中。
难度: medium
分类: System Design
标签: cache-aside, consistency, stale reads
参考答案摘要
答案 cache-aside 需要在写入数据库后(或前)同步刷新缓存,但在分布式环境里“DB 写成功、缓存更新失败/延迟”是常见故障模式。计数器的值对用户展示敏感:如果读优先命中缓存,就会读到旧值;如果又叠加重试机制,缓存与数据库的状态更容易出现短暂分叉。由于该方案本质上是 弱一致 并且对更新链路的成功与顺序很敏感,准确计数的风险反而更高。
本题提供 STAR 原则详细解答和技术解析,登录匠人学院学习中心即可查看完整答案。