组建自动化

自動建立定義如何編譯、打包與測試程式碼等軟體組建的過程

组建自动化(英语:Build automation,又称构建自动化自动化构建构建系统)指自动创建软件组建的一组进程,包括将计算机原始码编译二进制码英语binary code、将二进制码包装软件包以及运行自动化测试

概要

编辑

组建自动化原先是通过创建makefile来完成的,如今则主要使用两大类工具完成组建[1]

组建自动化工具(如Make、Rake、Cake、MS build、AntGradleCMake等)
这些工具的主要目的是通过编译和链接原始码等活动来生成组建工件。
组建自动化伺服器
这些基于Web的通用工具能够在预定或触发的基础上执行组建自动化实用程序。持续集成是组建自动化伺服器的类型之一。

根据自动化程度的不同有如下分类:

组建自动化工具

编辑

组建自动化工具允许自动化简单且重复的任务,这些工具会通过以正确的、特定的顺序执行任务并运行每个任务来计算如何达到目标。其又可分为任务导向工具与产品导向工具:任务导向工具用以描述网络在特定集合任务方面的依赖性;产品导向工具则根据其生成的的产品来描述事物[2]

组建自动化伺服器

编辑

虽然组建伺服器早在持续集成伺服器出现之前就已存在,但组建伺服器(英语:build servers)通常与持续集成伺服器(英语:continuous integration servers)在英语上是同义词。组建伺服器也可以并入软件生命周期管理(ALM)工具以及应用发布自动化英语Application release automation(ARA)工具中。

伺服器类型

  • 按需自动化On-demand automation):如在命令行界面中运行脚本的用户;
  • 计划自动化Scheduled automation) :如运行每日构建的持续集成伺服器;
  • 触发自动化Triggered automation) :如运行每次提交到版本控制系统的构建的持续集成伺服器。

分布式组建自动化

编辑

自动化是透过许多的编译器来达成,可能是工具在每一个步骤执行不同的编译器,或是用分布式编译[3]。分布式组建流程需要有机器智慧,了解代码的相依性,以便用正确的顺序进行分布式组建。

和持续交付和持续集成的关系

编辑

组建自动化是朝向持续交付(CD)和DevOps的第一步。组建自动化若结合持续集成(CI)、软件部署应用程式发布自动化英语application-release automation等程序,可以让组织渐渐的建立软件交付的最佳实务[4][具体情况如何?]

好处

编辑

在软件开发项目中,导入组建自动化的好处如下:

  • 要进行持续集成和持续测试英语continuous testing的必要条件
  • 提升产品质量
  • 加速编译和链接的处理
  • 消除重复的任务
  • 减少“不良的组建”
  • 消除关键人员的相依性
  • 建立组建历史以及发布历史,在调查问题时更方便
  • 因为上述的原因,可以节省时间和金钱[5]

相关条目

编辑

参考资料

编辑
  1. ^ Ceruzzi, Paul E. A history of Modern computing. The MIT Press. 2003. ISBN 978-0262532037. 
  2. ^ Clark, Mike. Pragmatic Project Automation: How to Build, Deploy, and Monitor Java Apps. The Pragmatic Programmers. 2004. ISBN 978-0974514031. 
  3. ^ Enos, Joe. Automated Builds: The Key to Consistency. InfoQ (C4Media Inc.). 2013 [September 16, 2015]. (原始内容存档于2021-10-22). 
  4. ^ Bashan, Shmuel; Bellagio, David E. Work Item Management with IBM Rational ClearQuest and Jazz: A customization Guide. IBM Press. 2011. ISBN 978-0137001798. 
  5. ^ Archived copy (PDF). [2008-09-19]. (原始内容 (PDF)存档于2008-11-23).