架构师



记得刚入职场的时候,公司有让大家做职业规划,我写的是往架构师方向发展,然而多年过去了,虽然一直朝这个方向努力,但至今还未成为一名真正的架构师。

一、什么是架构师

那么,什么是架构师呢,相信这是一个永恒的问题。很多知名大佬介绍自已的时候,都只说自已是架构师,如微信教父张小龙,Facebook创始人马克·扎克伯格等。当前,因为每个公司所处的阶段不同,公司对架构师的定位也有所不同,业务模式、应用场景也都不一样,对架构的要求也不一样。

1.1 在公司初创阶段

业务场景和需求的边界很难把握,有时候根本不需要架构师,产品需要快速的更新迭代和变现,需求频繁更新,这个时候需要的就是如何快速实现。当然如果公司成长以后,这个阶段就是欠下的技术债,埋下的坑,如果人员流动很频繁,后期系统维护成本是非常巨大的。

1.2 在公司稳定成长阶段

业务模式和应用场景边界都已经比较清晰,这个时候最需要架构师能对线上业务进行模块划分,系统拆分重构,并做好相关高可用的措施,以保证系统的稳定、安全、高效地运行。

不同的行业,对架构师的要求也不同,比如电商业务和AI领域,从架构到业务场景,完全是两个物种。

百度百科:系统架构师是一个既需要掌控整体又需要洞悉局部瓶颈并依据具体的业务场景给出解决方案的团队领导型人物。一个架构师得需要足够的想像力,能把各种目标需求进行不同维度的扩展,为目标客户提供更为全面的需求清单。

架构师实际上就是软件的总体设计师。具体来说是一个确认和评估系统需求,给出开发规范,搭建系统实现的核心构架,并澄清技术细节、扫清主要难点的技术人员。主要着眼于系统的“技术实现”。因此架构师应该是特定的开发平台、语言、工具的大师,对常见应用场景能马上给出最恰当的解决方案,同时要对所属的开发团队有足够的了解,能够评估自己的团队实现特定的功能需求需要的代价。系统架构师负责设计系统整体架构,从需求到设计的每个细节都要考虑到,把握整个项目,使设计的项目尽量效率高,开发容易,维护方便,升级简单等。

二、架构师的作用

架构师在整个软件系统开发过程中都起着重要的作用,并随着开发进程的推进而其职责或关注点不断地变化。

2.1 按软件开发过程维度来说

需求阶段:软件架构师主要负责理解和管理非功能性系统需求,比如软件的可维护性、性能、复用性、可靠性、有效性和可测试性等等。此外,架构师还要经常审查和客户及市场人员所提出的需求,确认开发团队所提出的设计;

架构设计阶段:架构师负责对整个系统架构设计,制定开发规范、开发计划,指导整个开发团队完成这个计划;

开发阶段:架构师则成为详细设计者和代码编写者的顾问,并且经常性地要举行一些技术研讨会、技术培训班等;

测试和交付阶段:协调做好相关测试和部署;

维护阶段:软件架构师就开始为下一版本的产品是否应该增加新的功能模块进行决策。

2.2 按职能维度

确认需求:架构师要懂得用户需求,理解用户真正想要什么,这使得架构师必须要和分析人员不断沟通,反复确认需求规格说明书,以此来保证他精准清楚用户需求。架构师会与很多人沟通,例如开发人员,项目经理,有时甚至是用户本身。架构设计的目的很明确,挖掘用户需求。

系统分解:在架构师认可需求规格说明书后,架构师已明确用户需求是什么,这时候就要看架构师的分解能力了。

系统分解包括纵向分解和横向分解:

横向分解是对系统分解成不同的逻辑层,确定层与层之间的关系。是指基于技术架构层次进行的人员角色分工和任务分解。常见的分层:

  • 应用层:主要负责具体的业务逻辑处理
  • 服务层:提供可复用的服务
  • 数据层:负责数据的存储和访问

分层注意事项:

  • 必须合理规划层次边界和接口
  • 禁止跨层次的调用及逆向调用

纵向分解是将不同的功能和服务分割开来,包装成高内聚低耦合的模块单元,有助于软件开发和维护,还便于不同模块的分布式部署,提高网站的并发处理能力和功能扩展能力。

技术选型:在系统分解后,架构师会最终形成软件整体架构。接下来,架构师的职责是技术选型。
前端到底用瘦客户端还是富客户端呢?数据库是用MySQL还是MSSQL又或是Oracle呢?在了解用户需求后,分解完系统后,技术选型是非常重要的环节,提出各个方向,再进行评估。不过,很多人都以为架构师是有决定权的,其实不是,架构师没有拍板的权力,最终通常由项目经理来决定。

架构师在技术选型阶段会提供参考信息给项目经理,项目经理再从预算、进度、人力、资源等各方面情况来权衡,最终确认。

制定技术规格说明:架构师在项目开发过程中是「灵魂人物」,并且要具备协调组织能力和懂得人员分工。

在制定技术规格说明阶段,架构师要协调起所有的开发人员,架构师通常会用技术规格说明书与开发人员保持沟通,让开发人员能从各个视角去观测、理解他们负责的模块或者子系统,确保开发人员能够按照架构意图实现各项功能。

三、架构师分类

架构师其实就是个title,每个公司称呼都可能不一样,和架构概念一样。

3.1 软件架构师

软件架构师是软件行业中的一种新兴职业,工作职责是在一个软件项目开发过程中,将客户的需求转换为规范的开发计划及文本,并制定这个项目的总体架构,指导整个开发团队完成这个计划。主导系统全局分析设计和实施、负责软件构架和关键技术决策的人员,比如这些架构师的title可能是Java架构师、Python架构师、LAPM架构师等等。

3.2 Web架构师

Web架构师是网站系统、功能、模块、流程的设计师,架构师,好比是高楼大厦的设计人员,通常一座大厦在建之前,都先由设计师将蓝图描绘出来,包括其形状、结构、尺寸、材料等等,然后建筑工程师带领工人们按照蓝图将大厦一层一层地建起来。

架构师也要看在什么样的公司,中小公司很多架构师都是全能的。通常公司规模和体系越大,分工会越细。大体可以这么分类:

  • 解决方案架构师
  • 系统架构师
  • 平台架构师
  • 业务架构师
  • 网络架构师
  • 移动架构师
  • 前端架构师
  • 大数据架构师

四、架构师具备素质能力

架构师应该具备的能力:

  • 精通某项技术,能够从本质上类比,触类旁通其他技术
  • 对等所有技术,只有合适和不合适,没有喜欢和不喜欢
  • 视野开阔,了解不同技术的优缺点; 知道使用某项开源技术实现某项业务需求,能够辨别重复造轮子
  • 精通设计模式,但又不泛用
  • 把系统拆分成多个子系统或模块。模块之间尽量松耦合,使得原先串行的开发任务变得可以并行发展
  • 能清楚系统的瓶颈在什么地方, 不断定位技术难度,开发进度,性能,内存等个方面的瓶颈;不断调整骨干力量解决瓶颈,在风险爆发之前消除隐患
  • 能做好前瞻性设计,预判到需求可能产生的变化

架构师团队内做的事情:

  • 沟通能力:各个方面都要了解,人人想法及规划都要知道,了解产品思想,用了什么方法实现的
  • 组织能力:组织推动各种技术的改进及功能的完善
  • 谈判代表:左右两难的时候的调解人
  • 设计模块及业务:通过图形化设计发现开发后才会发现的业务问题
  • 成本规划:通过过往经验评估成本及步伐
  • 愿望收集:不断收集建议及愿望,一步步实现
  • 传播布道:不断参与行业交流,提高理论及技术知识科普分享团队

五、总结

总之,风风雨雨经过这么多年,我觉得架构师的形成并不是看几本书,或是看几节视频就可以的。这需要在工作中积累大量的工作经验,以及不断的学习,才可以的。我一直在努力着!