系统设计面试

如何处理一个系统设计的面试题

系统设计面试是一个开放式的对话。他们希望你去主导这个对话

第一步:描述使用场景,约束和假设

把所有需要的东西聚集在一起,审视问题。不停的提问,以至于我们可以明确使用场景和约束。讨论假设。

  • 谁会使用它?
  • 他们会怎样使用它?
  • 有多少用户?
  • 系统的作用是什么?
  • 系统的输入输出分别是什么?
  • 我们希望处理多少数据?
  • 我们希望每秒钟处理多少请求?
  • 我们希望的读写比率?

第二步:创造一个高层级的设计

使用所有重要的组件来描绘出一个高层级的设计

  • 画出主要的组件和连接 (process on)
  • 证明你的想法

第三步:设计核心组件

对每一个核心组件进行详细深入的分析。举例来说,如果你被问到设计一个 url缩写服务,开始讨论:

  1. 生成并储存一个完成 url 的 hash
  • MD5 和 Base62
  • Hash碰撞
  • SQL还是NoSQL
  • 数据库模型
  1. 将一个 hased url翻译成一个完整的 url
  • 数据库查找
  1. API和面向对象设计

第四步:扩展设计

确认和处理瓶颈以及一些限制。举例来说就是你需要下面的这些来完成扩展性的议题吗?

  • 负载均衡
  • 水平扩展
  • 缓存
  • 数据库分片

论述可能的解决办法和代价。每件事情需要取舍。可以使用可扩展系统的设计原则来处理瓶颈。

附加

预估计算量

相关推荐
a努力。35 分钟前
宇树Java面试被问:数据库死锁检测和自动回滚机制
java·数据库·elasticsearch·面试·职场和发展·rpc·jenkins
源代码•宸1 小时前
Golang原理剖析(defer、defer面试与分析)
开发语言·经验分享·后端·面试·golang·defer·开放编码
Tisfy2 小时前
LeetCode 1292.元素和小于等于阈值的正方形的最大边长:二维前缀和(无需二分)+抽象速懂的描述
算法·leetcode·职场和发展
努力学算法的蒟蒻2 小时前
day60(1.19)——leetcode面试经典150
算法·leetcode·面试
期末考复习中,蓝桥杯都没时间学了2 小时前
力扣刷题记录2
算法·leetcode·职场和发展
阿拉伯柠檬3 小时前
网络层与网络层协议IP(一)
linux·网络·网络协议·tcp/ip·面试
天真小巫3 小时前
2026.1.19总结
职场和发展
敲敲了个代码4 小时前
UniApp 的 rpx是什么,跟rem比呢?
前端·javascript·面试·职场和发展·微信小程序·uni-app
橘颂TA4 小时前
【剑斩OFFER】算法的暴力美学——力扣 695 题:岛屿的最大面积
算法·leetcode·职场和发展
石去皿4 小时前
机器学习面试·易错速问速答 30 题
人工智能·机器学习·面试