在架构师面试过程中,架构设计是一个必不可少的环节。通常面试官会陈述系统的功能需求与性能需求,面试者要提出系统架构设计方案,并与面试官讨论方案里的设计折衷,方案选型与各个方案的优缺点。
那究竟什么是架构设计,architecture design 呢?
架构设计通常是指,为了满足特定的需求,我们定义系统组件,以及组件之间相互作用关系的过程。
比如说,你要满足一个个人主页的需求,系统架构只需要一个web-server,背后丢一个静态页就可以了。而如果你要满足一个十万人同时登陆的需求,系统架构就需要反向代理,web-server,service,DB,cache等诸多组件。
画外音:任何脱离业务需求的架构设计,都是耍流氓。
在软件工程中,架构设计是软件开发过程中的一个阶段,这个阶段侧重于顶层设计而不是细节设计。通常这个阶段需要设计整体的结构,组件,与组件关系。
总之,架构设计的目的是为了实现产品需求,业务需求,架构设计非常关注:
- 整体结构;
- 组件;
- 组件之间的关联;
举几个案例。
案例1,业务需求:“我想做一个全网搜索引擎,不复杂,和百度类似就行,两个月能上线吗?”
为了实现这个搜索引擎需求,整体的结构,组件,组件之间的关联,可能就是这样的。
案例2,业务需求:“我想做一个内容检索功能,不复杂,100亿数据,每秒10万查询而已,两个星期能上线吗?”
为了实现这个内容检索需求,整体的结构,组件,组件之间的关联,可能就是这样的。
案例3,业务需求:“检索的时效性,对用户体验来说很重要,在例子2的基础之上,必须检索出5分钟之前的新闻,1秒钟之前发布的帖子,不复杂吧?”
为了实现这个时效性需求,整体的结构,组件,组件之间的关联,可能就是这样的。
以上,就是架构设计。