组建自动化
外观
软件开发 |
---|
核心行动 |
范式与模式 |
方法论与框架 |
支持行为 |
实践 |
工具 |
标准与知识体系 |
组建自动化(英语:Build automation,又称构建自动化、自动化构建、构建系统)指自动创建软件组建的一组进程,包括将计算机原始码编译成二进制码、将二进制码包装成软件包以及运行自动化测试。
概要
[编辑]组建自动化原先是通过创建makefile来完成的,如今则主要使用两大类工具完成组建[1]:
- 组建自动化工具(如Make、Rake、Cake、MS build、Ant、Gradle、CMake等)
- 这些工具的主要目的是通过编译和链接原始码等活动来生成组建工件。
- 组建自动化伺服器
- 这些基于Web的通用工具能够在预定或触发的基础上执行组建自动化实用程序。持续集成是组建自动化伺服器的类型之一。
根据自动化程度的不同有如下分类:
组建自动化工具
[编辑]组建自动化工具允许自动化简单且重复的任务,这些工具会通过以正确的、特定的顺序执行任务并运行每个任务来计算如何达到目标。其又可分为任务导向工具与产品导向工具:任务导向工具用以描述网络在特定集合任务方面的依赖性;产品导向工具则根据其生成的的产品来描述事物[2]。
组建自动化伺服器
[编辑]虽然组建伺服器早在持续集成伺服器出现之前就已存在,但组建伺服器(英语:build servers)通常与持续集成伺服器(英语:continuous integration servers)在英语上是同义词。组建伺服器也可以并入软件生命周期管理(ALM)工具以及应用发布自动化(ARA)工具中。
伺服器类型
- 按需自动化(On-demand automation):如在命令行界面中运行脚本的用户;
- 计划自动化(Scheduled automation) :如运行每日构建的持续集成伺服器;
- 触发自动化(Triggered automation) :如运行每次提交到版本控制系统的构建的持续集成伺服器。
分布式组建自动化
[编辑]自动化是透过许多的编译器来达成,可能是工具在每一个步骤执行不同的编译器,或是用分布式编译[3]。分布式组建流程需要有机器智慧,了解代码的相依性,以便用正确的顺序进行分布式组建。
和持续交付和持续集成的关系
[编辑]组建自动化是朝向持续交付(CD)和DevOps的第一步。组建自动化若结合持续集成(CI)、软件部署、应用程式发布自动化等程序,可以让组织渐渐的建立软件交付的最佳实务[4][具体情况如何?]。
好处
[编辑]在软件开发项目中,导入组建自动化的好处如下:
- 要进行持续集成和持续测试的必要条件
- 提升产品质量
- 加速编译和链接的处理
- 消除重复的任务
- 减少“不良的组建”
- 消除关键人员的相依性
- 建立组建历史以及发布历史,在调查问题时更方便
- 因为上述的原因,可以节省时间和金钱[5]
相关条目
[编辑]参考资料
[编辑]- ^ Ceruzzi, Paul E. A history of Modern computing. The MIT Press. 2003. ISBN 978-0262532037.
- ^ Clark, Mike. Pragmatic Project Automation: How to Build, Deploy, and Monitor Java Apps. The Pragmatic Programmers. 2004. ISBN 978-0974514031.
- ^ Enos, Joe. Automated Builds: The Key to Consistency. InfoQ (C4Media Inc.). 2013 [September 16, 2015]. (原始内容存档于2021-10-22).
- ^ Bashan, Shmuel; Bellagio, David E. Work Item Management with IBM Rational ClearQuest and Jazz: A customization Guide. IBM Press. 2011. ISBN 978-0137001798.
- ^ Archived copy (PDF). [2008-09-19]. (原始内容 (PDF)存档于2008-11-23).