报名参加CloudWeGo黑客松,奖金直推双丰收! 了解详情
写点什么

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

  • 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:434353
用户头像

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

关注

评论

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

美团买菜基于 Flink 的实时数仓建设

Apache Flink

大数据 flink 实时计算

不断进化!奇点云助豫园股份构建集团统一战略的数据平台

奇点云

数字化转型 奇点云 豫园股份

ThreadLocal变量存储为什么不用Map

M

原创 ThreadLocal Java'

基于阿里云 Serverless 容器服务轻松部署企业级 AI 应用

阿里巴巴云原生

阿里云 Serverless Kubernetes 云原生 ASK

5款超级好用的开发效率工具,建议收藏!

引迈信息

程序员 前端 低代码 开发效率

证券行业异构系统众多,微服务和网格如何全都要

网易数帆

微服务 云原生 服务网格 证券行业

AIGC繁花,绽放在精耕的算力土壤之上

脑极体

AI 服务器

博睿数据应邀出席第五届双态IT北京用户大会,分享《如何帮助用户构建高级可观测性》

博睿数据

可观测性 AIOPS 智能运维 博睿数据 IT行业

三维人脸建模和驱动技术,让数字人快速“活”起来

华为云开发者联盟

人工智能 华为云 数字人 华为云开发者联盟 企业号 6 月 PK 榜

Ubuntu安装Python

Geek_7ubdnf

一小时快速拆解 Milvus 2.2.9

Zilliz

非结构化数据 Milvus Zilliz 向量数据库 zillizcloud

WiFi7来了,WiFi6会下岗吗?

白洞计划

wifi

VMware虚拟机和主机传输文件

Geek_7ubdnf

不一样的ECS U实例

六月的雨在InfoQ

MySQL nginx 阿里云ECS U 6 月 优质更文活动

魏可伟受邀参加 2023 开放原子全球开源峰会

KaiwuDB

KaiwuDB 2023开放原子全球开源峰会

Koordinator 最佳实践系列:精细化 CPU 编排

阿里巴巴云原生

阿里云 云原生 Koordinator

ChatGPT与Web的完美结合:创造一加一大于二的化学反应

加入高科技仿生人

Web 低代码 ChatGPT

软件测试/测试开发丨Python 常用数据结构-列表

测试人

Python 程序员 软件测试 自动化测试

SpringBoot进阶学习?看这篇就够了!

程序员小毕

程序员 程序人生 架构师 springboot java面试

Kubernetes关键组件解析

穿过生命散发芬芳

k8s 6 月 优质更文活动

TiDB 7.1 LTS 发版:为关键业务提供业务稳定性和多租户场景支持

PingCAP

数据库 开源 TiDB

《OpenHarmony 共建地图 2.0》在2023开放原子全球开源峰会发布

新消费日报

直播预告 | 博睿学院:AIOps利器-混沌工程实践

博睿数据

可观测性 AIOPS 智能运维 博睿数据 博睿学院

软件测试/测试开发丨Python 常用数据结构-元组

测试人

Python 程序员 软件测试 自动化测试 测试开发

ICASSP 2023 | 深度窄带网络消除实时语音通信中的干扰音

阿里技术

实时语音 音频处理

平凯星辰重磅支持 2023 开放原子全球开源峰会,开源数据库分论坛成功召开

编程猫

提升网站速度,选择香港主机的三大理由!

一只扑棱蛾子

香港主机

WiFi7来了,WiFi6会下岗吗?

脑极体

wifi

为数据弹性而生,阿里云云原生存储再提速

阿里巴巴云原生

阿里云 Serverless 云原生 Fluid EFC

更好的保护你的数据KEY

坚果

6 月 优质更文活动

YRCloudFile 分布式存储加速基因测序 解锁生命密码

焱融科技

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