logo

排行榜系统如何实现可扩展性(Scalability)?读写路径应该如何拆分?Redis 节点的 QPS 能力与数据反规范化(denormalization)有什么关系?

How do you achieve scalability in a leaderboard system? How should you separate read/write paths, and what is the relationship between Redis QPS capability and denormalization?

题目类型: 技术面试题

这是一道技术面试题,常见于澳洲IT公司面试中。

难度: hard

分类: system-design, scalability

标签: scalability, read-write-separation, denormalization, qps, redis

参考答案摘要

TL;DR 读扩展依赖缓存层(Redis/CDN/客户端缓存)来承载大量 leaderboard view 请求;写扩展依赖数据分片或内存架构(Sorted Set)来支撑高频 score updates。通过拆分读写路径(read path / write path)并在读侧使用反规范化数据,可以显著提高吞吐与降低延迟。文中提到 Redis 节点在峰值可处理约 40k QPS,超过后需要分片。 ...

本题提供 STAR 原则详细解答和技术解析,登录匠人学院学习中心即可查看完整答案。

← 返回面试题库

排行榜系统如何实现可扩展性(Scalability)?读写路径应该如何拆分?Redis 节点的 QPS 能力与数据反规范化(denormalization)有什么关系?

Hardsystem-design

想查看完整答案?

登录匠人学院学习中心,获取 STAR 格式回答和详细技术解析

前往学习中心查看答案