如何才能称得上是一名架构师?

2007 年 8 月 21 日

架构

在 MSDN 开发者中心的博客上有一篇很有意思的文章,作者在文中讲述了在微软的文化(至少是其文化的一部分)中架构师的定义,带我们对软件架构师这个角色所经历的历史进行了回顾,并描绘了使架构师变得至关重要的驱动力。他从当架构师还是可有可无的那段时期开始讲起:

在不久以前,开发平台还是更加倾向于自我封闭,自给自足的。从健壮而复杂的环境——比如主流的 COBOL,到轻量级且易于理解的 xBase 语言,最为重要的技术决定早就已经有人帮你做好。对于软件项目而言,这是利益和障碍共存的。其中一项好处就是,当人们在某一点存在有共识的时候,就无需浪费时间来争论作这件事情的最佳方式是什么了。

文章的作者 Dagum 接着又对我们当前所使用的基本栈式架构的多样性进行了简单说明,以及这种灵活性最终所带来的代价:我们必须要有效的管理系统的复杂性。

由于面向组件的软件开发方式的出现,我们可以根据特定的问题来选择最佳的平台。但尽管这样,对很多程序员来说,切换到新的平台上进行开发也是件很头疼的事情。所以一个好的架构师的首要目标就是把新的平台和 API 的复杂性隐藏到更为简洁的结构之后,让它们更加注重于待解决问题(特别是一个业务问题)的领域,当然最重要的就是让普通的程序员容易理解掌握。 软件架构就是这样变成了以安全、及时、精确的方式开发商业解决方案的一条坦途。这条路完全是由技术决策铺成的,这些决策是至关紧要的。架构师必须要做出种种决策,来方便开发人员的工作。

和过去相比,我们现在不再是从厂商那里购买通用型的软件,而是根据要开发的商业解决方案来做出决策。

Dagum 解释说这给架构师的职责和定义带来了一场突如其来的变革,从以应用程序为中心,转到了更加侧重于企业化乃至以基础设施为关键着眼点的职责上,他还详述了进来新词满天飞的架构变革的趋势——SOA——背后的主要驱动力。他在讲述早期软件架构师的定义的时候,列举了以下四个最佳实践:

  • 设计模式(Design Patterns),从“四人帮”的那本设计模式书发起
  • 架构模式(Architecture Patterns),Dagun 以 Smalltalk 中使用的 MVC 模式来加以举例说明
  • 反模式(Anti-Patterns),它的名字就准确说明了它的含义
  • 框架,他以 ORM 映射工具和 MVC 支持框架来举例说明

随后,他又解释了随着架构师一职被人们正式认同,相应的角色和责任是如何被转变到一个更高的抽象层次上的,它们又是如何围绕下面三个范畴巩固起来的:

  • 基础架构师(Infrastructure Architect),主要以硬件 / 网络 / 操作系统这种平台的微架构为中心
  • 解决方案架构师(Solution Architect),他的职责要跨越软件 / 数据库 / 硬件的界限,来为特定的解决方案定义一个一栈式的架构
  • 企业架构师(Enterprise Architect),他更像是一个管理型的角色,他的责任和范围是覆盖整个组织的

最后,Dagum 以对未来的展望结束了全文。他还特别提到了 SOA,MDA,软件工厂,软件即服务(Software as a Service)和 Web 2.0。随着时间的推移,人们心目中对架构师定义也有了不同的理解,Dagum 在文中对这种变化及其背后的驱动力做了归纳。

查看英文原文: What is an Architect anyway?

2007 年 8 月 21 日 03:00 296
用户头像

发布了 197 篇内容, 共 43.5 次阅读, 收获喜欢 15 次。

关注
架构

评论

发布
暂无评论
发现更多内容

iOS造轮子 - UITableView字母索引条

iOSer

ios 面试题 UITableView iOS面试

面试官,ThreadLocal 你要这么问,我就挂了!

小傅哥

Java 小傅哥 面试题 ThreadLocal 开放寻址

极客大学 - 架构师训练营 第二周

9527

不一样的面向对象(一)

书旅

php 面向对象

架构师训练营第一期-第二周课后-作业二

架构师训练营第一期

网易伏羲问鼎全球AI文创大赛:用户可零门槛生产音视频动画

核桃Eason

人工智能 AI 动画 网易

LeetCode题解:83. 删除排序链表中的重复元素,递归,JavaScript,详细注释

Lee Chen

LeetCode 前端进阶训练营

动图演示:手撸堆栈的两种实现方法!

王磊

Java 数据结构 算法

双亲委派模型与 Flink 的类加载策略

Apache Flink

flink

学习Java的三个阶段(学习目标+知识点),一起努力吧!

Java架构师迁哥

高难度对话读书笔记—认知篇

wo是一棵草

滴滴开源AgileTC:敏捷测试用例管理平台

滴滴技术

开源项目 滴滴技术 滴滴开源

10个常见的软件架构模式

GuoYaxiang

架构模式 软件架构 架构设计

软件开发的 5 条核心原则,让工作事半功倍

沉默王二

程序员 软件开发

架构师 0 期 | 大数据相关技术

刁架构

架构师训练

架构师训练营第一期-第二周课后-作业一

架构师训练营第一期

TensorFlow 篇 | TensorFlow 2.x 基于 Keras 的模型构建

Alex

tensorflow keras model

JS中的Timing API

Lawliet

Java经典面试题详解,突围金九银十面试季(附详细答案)

Java架构师迁哥

小前端探索HTTP

Lam

JavaScript 面试 前端 网络 HTTP

从 LRU Cache 带你看面试的本质

码农田小齐

算法

HashMap源码解析

彭阿三

hashmap HashMap底层原理

聊聊布隆过滤器

海星

线上医疗未来的发展

anyRTC开发者

ios 音视频 WebRTC RTC 安卓

LeetCode题解:83. 删除排序链表中的重复元素,迭代,JavaScript,详细注释

Lee Chen

LeetCode 前端进阶训练营

你的页面健康吗?

Lam

JavaScript 前端 浏览器 性能分析 web前端

多端消息推送的设计思考

Nil

Java spring 设计模式 消息推送

C++的匿名函数(lambda表达式)

良知犹存

c++ 编程开发

免费CA证书安装配置与背后原理浅析

陈德伟

99%的人都能看懂的分布式系统「补偿」机制

华为云开发者社区

分布式 高可用 系统

大作业二:总结

zcj

如何才能称得上是一名架构师?-InfoQ