组建自动化(英语:Build automation,又称构建自动化、自动化构建、构建系统)指自动创建软件组建的一组进程,包括将计算机源代码编译成二进制码、将二进制码包装成软件包以及运行自动化测试。
概要
组建自动化原先是通过创建makefile来完成的,如今则主要使用两大类工具完成组建[1]:
- 组建自动化工具(如Make、Rake、Cake、MS build、Ant、Gradle、CMake等)
- 这些工具的主要目的是通过编译和链接源代码等活动来生成组建工件。
- 组建自动化服务器
- 这些基于Web的通用工具能够在预定或触发的基础上执行组建自动化实用程序。持续集成是组建自动化服务器的类型之一。
根据自动化程度的不同有如下分类:
组建自动化工具
组建自动化工具允许自动化简单且重复的任务,这些工具会通过以正确的、特定的顺序执行任务并运行每个任务来计算如何达到目标。其又可分为任务导向工具与产品导向工具:任务导向工具用以描述网络在特定集合任务方面的依赖性;产品导向工具则根据其生成的的产品来描述事物[2]。
组建自动化服务器
虽然组建服务器早在持续集成服务器出现之前就已存在,但组建服务器(英语:build servers)通常与持续集成服务器(英语:continuous integration servers)在英语上是同义词。组建服务器也可以并入软体生命周期管理(ALM)工具以及应用发布自动化(ARA)工具中。
服务器类型
分散式组建自动化
自动化是透过许多的编译器来达成,可能是工具在每一个步骤执行不同的编译器,或是用分散式编译[3]。分散式组建流程需要有机器智能,了解程式码的相依性,以便用正确的顺序进行分散式组建。
和持续交付和持续整合的关系
组建自动化是朝向持续交付(CD)和DevOps的第一步。组建自动化若结合持续整合(CI)、软件部署、应用程式发布自动化等程序,可以让组织渐渐的建立软件交付的最佳实务[4][具体情况如何?]。
好处
在软体开发专案中,导入组建自动化的好处如下:
- 要进行持续整合和持续测试的必要条件
- 提升产品品质
- 加速编译和连结的处理
- 消除重复的任务
- 减少“不良的组建”
- 消除关键人员的相依性
- 建立组建历史以及发布历史,在调查问题时更方便
- 因为上述的原因,可以节省时间和金钱[5]
相关条目
参考资料
Wikiwand in your browser!
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.