前端系统设计简介
与编码和问答题不同,系统设计面试是开放式面试,没有正确答案。 面试官会给您一个模糊的问题或场景,您需要与面试官合作,在白板上(如果是虚拟面试,则使用一些协作绘图应用程序)设计出合适的软件来回答问题。 这类似于某些公司的流程,即工程师撰写技术设计文件,概述他们正在进行的项目的可能方法,解释技术决策,并与同事讨论取舍,但您必须在 30-60 分钟内完成。
系统设计面试通常是给有一定年限工作经验的应聘者(又称非应届毕业生),您在系统设计面试中的表现对您将获得的职位级别有重要影响。 在大多数情况下,系统设计面试失败将导致整体被拒。 通过系统设计面试非常重要!
然而,鉴于系统设计面试的开放性,与编码面试相比,系统设计面试的练习难度要大得多。 许多应聘者也没有构建各种系统的实际经验,因此在回答系统设计面试问题时很难从经验中吸取教训。 此外,用于前端系统设计的资源非常少。 大多数现有的系统设计资源都是针对普通软件工程师的,因此侧重于分布式系统。
GreatFrontEnd 的系统设计资源也许是您能找到的最全面的资源,将帮助您轻松应对前端系统设计面试!
前端与后端系统设计
在传统的软件工程师系统设计面试中,应聘者会被要求描述分布式系统的架构,通常涉及 Web 服务器、负载均衡器、缓存、数据库、微服务、任务队列等。 对于前端工程师来说,系统设计面试略有不同,与后端相比,面试更注重客户端以及客户端与服务器之间的 API 设计。
方面 | 后端 | 前端 |
---|---|---|
收集需求 | 需要 | 需要 |
架构/高级设计 | 分布式云服务 | 应用/组件 |
事后估算 | 需要 | 不需要 |
系统组成 | 云服务(例如负载平衡器、应用服务器、数据库、文件存储、缓存、消息队列、CDN) | 应用模块(模型、视图、控制器) |
数据模型 | SQL Schema | 应用状态 |
组件之间的 API 类型 | 网络(任何协议) | 网络(HTTP、WebSocket)、JavaScript 函数 |
关注领域 | 可扩展性、可靠性和可用性 | 性能、用户体验、可访问性、国际化 |
不太重要(可作为黑盒处理) | 客户端 | 服务端 |
在郑浩的博客上阅读有关前端和后端系统设计面试之间的区别的更多内容。
例如,在后端和前端系统面试中都可能被问到的一个典型问题是关于设计 Twitter 动态 UI 的问题。
- 后端:容量估算,设计数据库模式,如何确保服务能够随着流量扩展,如何生成用户的 Twitter 信息流?
- 前端:你如何实现与推文的交互,如何在动态中实现分页,以及用户如何创建新推文?
正如您所看到的,前端系统设计面试的重点可能与后端截然不同,要回答好这些问题需要采用不同的方法。
您将在本指南中学到什么
我们的前端系统设计指南分为两部分,首先您将深入了解系统设计面试的内容,然后使用 RADIO 框架深入研究一些前端系统设计案例。