写点什么

在敏捷开发过程中,架构师是鸡还是猪?

  • 2013-08-15
  • 本文字数:1663 字

    阅读完需:约 5 分钟

在敏捷项目中,架构师可以扮演重要的角色吗?还是说,因为他们倾向于“预先做大量设计(big design up front)”而只能成为辅助角色?最近,微软的企业架构师 Nick Malik 在一篇博文中对该话题进行了探讨,他的结论是,架构师完全可以在使用 Scrum 的软件项目中扮演关键角色。

Malik 的博文源于一个项目。在这个项目中,他试图把架构实践活动作用于 Scrum 过程。在文章的开头,他就立即断言,软件架构与敏捷开发过程并冲突。不过,他也承认,在一个交付周期较短的 Scrum 项目中,花费数月时间编写文档和图解系统的传统架构实践活动“相当傻”。但是,必须承认,任何软件项目——包括通过 Scrum 开发过程交付的项目——都有一个基本的软件架构。

软件架构的价值在于,它对系统自身核心基础设施做一系列关键决策:哪里需要泛化?要使用分层模式吗?如果使用,每一层的职责是什么?每一层包含哪些模块以及为什么要创建这些模块?如何在层和组件之间划分系统的职责?如何将模块进行大规模部署?信息如何在模块之间以及系统与外围系统之间流转?

这些问题的答案可以说明一个系统的架构是什么样子。

据 Malik 说,做每一项选择都要仔细平衡系统的一连串质量需求。软件架构师在软件架构职责的三个不同层次上工作时均需要考虑这些需求。

原始地址

最上面一层称作“校准过程(Aligning Processes)”,每季度或者每半年发生一次,解决整个组织的信息和商业策略相关的架构问题。这一层的输出是组织的未来软件模型。第二层包括“平衡过程(Balancing Processes)”,它与给定的软件项目相关联,可能发生在前面几次Scrum 冲刺的推进过程中。Malik 解释说,在这一层会对系统的逻辑架构进行精心设计。

这些过程考虑单一系统的需求,但仅仅决定几个方面的问题,包括为什么软件要分成模块、层和组件,如何进行职责划分,以及最终系统使用特定技术部署到特定的环境以后是什么样子。

最后,该模型的最底层是“实现过程(Realization Processes)”。据Malik 说,这一层是“架构变成软件的地方”,架构师做出具体的设计决 ,软件开发人员按照决定构建系统。Malik 承认,开发人员可能不接受架构师选择的设计模式,即便如此,“开发团队还是极有可能按照架构师的描述实现软件架构,但是可以改进它”。

那么,在实践中,对于一个给定的Scrum 软件开发过程,如何开展这项工作呢?Malik 直接在“冲刺规划(Sprint Planning)”会议之前增加了一个阶段。原先,可以从优先“产品待办事项列表(Product Backlog)” 阶段直接进入到冲刺规划会议及后续软件冲刺阶段。现在,项目团队插入了“冲刺前Story 审查(Pre-Sprint Story Review)”阶段,用于对Story 进行改进及架构评估。

原始地址

Malik 建议在冲刺规划会议前一周执行这个专注于架构的新步骤。

在冲刺规划会议前的一周里,那些与产品经理一起工作的人可以改进 Story、增加约束、完善描述和验收标准。这时,架构师开始发挥作用。他完成了上述模型中的“平衡”任务,将有(或可以创建)一份描述软件系统架构的概要文档,并且能够把文档与受该设计影响的具体 Story“链接”起来。

Malik 的结论是,在敏捷项目中,一名架构师是“鸡”还是“猪”取决于他在哪一层。在精心设计第一层和第二层的时候,架构师是团队的一名普通参与成员,即扮演“鸡”的角色;当在第三层工作的时候,架构师是一名投入大量时间与精力的参与者,即扮演“猪”的角色。这项由Malik 推动的活动继续对架构师在敏捷实践中所扮演的角色进行研究。在今年早些时候的一篇博文中,Malik 提出,架构师天生敏捷,他们注重通过增量过程完成高价值的活动,这一点与敏捷精神一致。由于企业试图提高软件开发的效率,同时又希望能够避免增加架构方面的负担,所以敏捷与架构的交点仍然是一个热门领域。

查看英文原文: Architects: Chickens or Pigs in an Agile Development Process?


感谢马国耀对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2013-08-15 01:434742
用户头像

发布了 256 篇内容, 共 100.6 次阅读, 收获喜欢 12 次。

关注

评论

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

2026年海外社交媒体分析服务商 TOP10

沃观Wovision

社交媒体 海外社交媒体监控 社媒分析

京东商品列表API:关键词搜索与多维度筛选

Datafox(数据狐)

京东API 京东商品列表API 京东数据采集 京东数据 关键词搜索京东列表接口

Android动效探索:彻底弄清如何让你的视频更加酷炫

vivo互联网技术

android ffmpeg 跨平台 OpenGL ES MediaPlayer

大厂集体押注 SDD!阿里、腾讯、亚马逊都在用的规范驱动开发,优势在哪?坑怎么避?

莫尔索

codex AI编程 cursor kiro Claude Code

SOLO Coder:从规划到执行,智能调度多智能体

北京中暄互动广告传媒有限公司

一文解析得物自建 Redis 最新技术演进

得物技术

redis Proxy 同城双活

基于 IPIDEA 的 SERP 结构化数据抽取与趋势监控的工程化实践

海拥(haiyong.site)

专业国外社交媒体分析服务如何实现舆情溯源、影响评估与策略建议

沃观Wovision

社交媒体 海外社交媒体监控 社交媒体监测 社媒分析

启信宝《2025全国采购地图》:藏在县城的“隐形冠军”,撑起你的购物车

合合技术团队

人工智能 大数据 算法

2025企业级ITSM产品推荐:年度IT服务管理升级指南

不想秃头

IT IT服务 IT服务管理

用AI让藏品说话项目开发笔记

严学峰

AI编程 AI编程助手

吉大正元PKI终端安全中间件已适配鸿蒙,共筑安全可信的基础设施

新消费日报

详细指南:DNS缓存的作用、危害与清理方法全解析

防火墙后吃泡面

英特尔和生态伙伴联合发布双路冷板式全域液冷服务器

科技经济

YashanDB数据库的存储引擎技术及创新实践解析

数据库砖家

财务 RPA 实战指南:从功能剖析到厂商选型

Techinsight

黑龙江等保测评中攻防演练的测评重点与注意事项

等保测评

网络安全 信息安全 数据安全 黑龙江等保测评 哈尔滨等保测评

YashanDB数据库的弹性扩展能力分析

数据库砖家

数据说话,节能落地:MyEMS 开源系统,让能源消耗可视化、优化可执行

开源能源管理系统

开源 能源管理系统

京东API详解:如何获取商品标题、价格和库存

Datafox(数据狐)

京东API 京东商品详情API 京东数据采集

黑龙江等保测评二级:材料与时间规定解析

等保测评

网络安全 信息安全 数据安全 黑龙江等保测评 哈尔滨等保测评

绥化等保测评:适用企业及核心侧重点解析

等保测评

网络安全 信息安全 数据安全 黑龙江等保测评 哈尔滨等保测评

黑龙江等保测评中日常安全巡检的测评重点与注意事项

等保测评

网络安全 信息安全 数据安全 黑龙江等保测评 哈尔滨等保测评

工业设备机械组装太“重”?一套MES系统让重型制造变“轻”又“准”

万界星空科技

mes 万界星空科技mes 制造业转型 机械组装mes 工业设备mes

一键对比:主流国外社交媒体分析网站功能一览

沃观Wovision

社交媒体 社媒监测 海外社交媒体监控 社媒分析

SOLO 新增多任务列表:并行开发,效率翻倍

北京中暄互动广告传媒有限公司

强大的Bash自动化测试框架Bats-core

qife122

bash automation

2026年出海企业必须知道的十个国外社交媒体分析网站

沃观Wovision

社交媒体 社媒监测 海外社交媒体监控 社交媒体监测 社媒分析

出海企业如何选择最好用的媒体分析工具?

沃观Wovision

社交媒体 社媒监测 海外社交媒体监控 社媒分析

使用Playwright MCP实现UI自动化测试:从环境搭建到实战案例

测试人

强强联合!枫清科技携手麒麟OS发布「云边端协同AI智能体联合解决方案」

Fabarta

在敏捷开发过程中,架构师是鸡还是猪?_研发效能_Richard Seroter_InfoQ精选文章