英文原文:A software architect is not a senior developer
本文的作者 Armel Nene 是 ETAPIX Global 公司的首席架构师,他居住在伦敦,他参与过的开源项目包括 Apache Lucene,,Apache Nutch, Liferay 和 Pentaho 等
如今很多的公司的 IT 部门仍然认为招聘一个的程序员,他同样也能承担软件架构师的角色。
程序员对整个软件生命周期很了解,他们可以经过培训成为架构师,但他们不等同于架构师。一个软件架构师首要的和重要的是他的远见。如果一个架构师拥有一些软件开发经验,那会更好,但大多时候,他们面对的是一个多语言的复杂环境。在第一行代码开始编写之前,架构师需要制定出业务需求如何转变成解决方案。这不仅仅需要业务环境的相关知识,从业务操作到客户环境,他还需要向公司上级勾画出一个令人信服的系统。如果有些问题不事先考虑,如扩展性,访问延迟问题,安全问题,系统开始开发时会忽略这些。而程序员了解自己的团队,了解他们的能力。程序员知道如何管理工作进度,确保开发中的软件如何实现架构设计的目标。
架构师能决定的是需求应该如何开发才能满足业务需要,例如:
这个业务分布全球,业务在需求上需要网站响应延迟不超过 3 秒——不管用户在什么地方,网站少要能承受 10 万以上的用户访问量。
上面的需求涉及的是系统的架构,而不是形如我们如何用 Oracle 数据库来对用户安全认证的问题。
有很重要的一点需要注意,很多的软件架构师在之前都是程序员(比如我自己),尽管如此,很多的程序员对架构设计并不感兴趣。决定一个系统是该使用 Tomcat 还是 Glassfish,是否要用 Apache Webserver 做负载均衡,这属于架构事务。做代码审查,确保设计模式被正确的应用,这是程序员的事务。程序员可以决定开发方法,比如使用敏捷开发方法,但需要项目经理的认可。架构师要参加项目各方一起的会议:用户,经营方,基础设施提供方,开发,测试人员。当用户询问为什么系统缓慢时,他们会找架构师,架构师则会找开发负责人研究目前的开发是否达到了架构设计目标,或看看架构设计上是否有缺陷。
我是一名软件架构师,我可以轻松的把我的见解表达给开发团队,但同时我也是一名程序员,我仍然热爱编程。我在一个软件架构协会工作,经常会遇到一些没有开发经验的架构师,我不认同他们的这种出身。软件架构师应该了解各种语言的特点,而不是只偏爱自己喜欢的那种。
我希望有更多的软件公司能认识到在软件项目中架构师的价值——不论项目有多大有多小。