软件开发实践之持续集成

简介: 软件开发实践之持续集成

持续集成是一种软件开发实践,团队成员频繁将他们的工作成果集成在一起(通常每人每天至少提交一次,这样每天就会有多次集成);每次提交后,自动触发运行一次包含自动化验证集的构建任务,以便能尽早发现集成问题。早在 20 世纪 80 年代,微软 Office 产品研发团队就使用一种开发实践,称作每日构建(daily build),也叫每晚构建(nightly build)。它是指每天定时自动执行一次软件构建工作,也就是将当前版本控制系统中的源代码检出到一个构建环境(即没有安装集成开发环境的干净机器)中,对其进行编译、链接、打包的过程。执行每日构建有助于确保开发人员明确了解他是否在前一天的代码编写过程中引入了新的问题。每日构建通常包含少量的自动化冒烟测试,这可以帮助团队确定是否新的变更破坏了原有的功能。其关键部分在于,每次构建一定要包含新的代码修改和测试。“冒烟测试” 这一术语来源于电子硬件测试。硬件样品只要通电后没有冒烟,就说明该硬件最基本的质量要求达到了。

一次集成过程

  1. 开发人员将代码提交到代码仓库;
  2. 持续集成服务器按一定的时间间隔(如每隔 1 分钟)对代码仓库进行轮询,发现有代码变更。
  3. 持续集成服务器自动将最新代码检出到已准备好的专用服务器上(如果应用规模不大,可以与持续集成服务器是同一台机器)。
  4. 在专用服务器上运行由持续集成服务器指定的构建脚本或命令,对最新代码进行检查(如代码动静态扫描、编译打包、运行单元测试、部署并运行功能测试等)。
  5. 运行结束后,将验证结果(成功或者失败)反馈给开发团队。

六步提交法

纪律是团队高效协作的保障,每个人都应该遵循下面 6 个工作步骤:一、检出最近成功的代码工程师开始工作时(例如工作日早上刚刚开工认领了一个新的开发任务),就要将最近一次构建验证成功的代码版本从团队的开发主干上检出(checkout)到自己的开发工作区中。二、修改代码在个人工作区中对代码进行修改(包括实现产品新功能的代码,甚至编写对应功能的自动化测试用例)。三、第一次个人构建当开发工作完成并准备提交时,首先执行一个自动化验证集,对自己工作区的新代码执行第一次个人构建(有时也被称为本地构建),用于验证自己修改的代码质量是否达标。四、第二次个人构建从“检出代码”到“第一次个人构建完成”这段时间内,很可能在开发主干上有其他成员已提交了新代码,并通过了持续集成的质量验证。此时,就需要将这个版本的代码与自己本地修改的代码进行合并(merge),然后再次执行一次质量验证,确保自己的代码与其他人的代码都没有问题。五、提交代码到团队主干当第二次个人构建成功以后,提交代码到团队开发主干。六、提交构建持续集成服务器发现这次代码变更,立即开始执行提交构建,运行自动化质量验证。如果这次构建失败,则应该立即着手修复,并马上通知团队成员,禁止其再向团队开发主干提交代码,并且不要检出这个版本。

四个关键点

一、六步提交法中的 3 次验证有什么作用?3 次验证分别是第 3、4 和 6 步。命令相同,脚本一致,为什么还要执行 3 次呢?第 3 步的个人验证目标是验证开发者自己修改过的代码是否正确。第 4 步的个人验证是确保其他人的代码与自己的代码合并后,两部分的代码质量都没有问题。第 6 步的提交构建验证是在一个干净且受控环境中执行与第 4 步个人构建相同的内容,以确保开发人员的本次提交是完整且无质量问题的,没有遗漏。二、个人验证一定要做两次吗?第一次个人验证的目标是验证自己的修改是符合质量预期的。第二次个人验证的目标是验证自己改动的代码和其他人提交的代码合并在一起,也符合质量预期。三、如何确保在提交前执行个人构建?一种方式是在提交代码之时,由持续集成平台通过钩子(hook)捕获提交事件,在代码合并到主干之前,强制进行第二次个人验证。当然,我们也可以通过团队口头 约定的方式,要求团队成员遵守这一要求。四、每次构建应该包含哪些质量验证内容?自动化单元测试并不能覆盖软件的所有运行场景。因此,除单元测试以外,我们仍旧希望在个人验证环节和提交构建验证中能运行更丰富的质量验证集合,如代码动静态扫描、代码规范检查、构建验证测试等。在条件允许的情况下,如果能够运行所有的自动化质量保证手段,就更棒了!构建验证测试(build verification test)是指检查如下内容:

  1. 构建结束后生成的二进制包是否包含了正确的内容,例如配置文件的完整性。
  2. 这个构建结果是否能够正确安装并正常启动运行起来。
  3. 启动后最基本的功能是否可以使用,如用户登录等。

代码规范检查的工具相对丰富且成熟,而且最容易执行。它与自动化测试相比,执行成本较低。不需要团队自行编写大量代码,只需要制订团队的编码规范,并在规范检查工具中配置相应的扫描规则,即可使用。

自查表

如果想知道自己的团队是否达到了持续集成的最佳状态,则可以从下面 6 个方面进行自我检查:

  1. 主干开发,频繁提交;
  2. 每次提交应该是一个完整的任务;
  3. 让提交构建在 10 分钟以内完成;
  4. 提交构建失败后应禁止团队成员提交新代码,也不许其他人检出该代码;
  5. 立即在 10 分钟内修复已失败的提交构建,否则回滚代码;
  6. 自动化构建验证通过后,对软件质量有比较大的信心;

在团队中实施持续集成实践

  1. 构建脚本化,搭建持续集成框架;
  2. 向构建中添加已有的自动化验证集合;
  3. 选择利于持续集成的分支策略;
  4. 建立六步提交法;
  5. 持续优化;
  6. 工程师改变习惯,并提升技能;

工程师的开发习惯

在没有进行持续集成实践之前,很多公司对开发工程师的代码提交粒度和频率并没有太多要求,尤其是使用传统瀑布开发方法的组织。如果工程师习惯于长时间不与其他人的代码进行集成,则在刚刚开始使用持续集成实践时,很难立即达到前面所说的“持续集成最佳状态”,如小步提交、代码完整、不影响已有功能等。但是,如果能够遵循第 6 章中对需求拆分的实践,则有助于加快质量反馈速度,达成良好的持续集成效果。强调开发质量和质量打磨周期的持续缩短是影响工程师习惯的入手点。

视而不见的扫描问题

扫描的结果常会被工程师忽视。其原因可能有两个:

  1. 团队成员对扫描规则没有达成一致,部分工程师对其中的问题有异议,但这种异议被管理者所忽视。
  2. 扫描出来的问题太多,无从下手修复。

第一个问题的原因是团队技术管理问题,代码规范没有统一标准。此时,首先应该由团队技术负责人与团队一起学习代码规范,讨论并制订团队的代码标准,并记录达成一致的检查项,再进行自动化扫描。第二个问题通常发生在产品研发进度紧张的时候。此时应该执行“童子军营地法则”,即保持质量指标不再恶化,例如,“每次提交代码都让问题数减少,至少不能增加”;或者限期整改,如“3 个月内将严重问题清零”。同时,也可以开发一些方便易用的工具,工程师可以用它方便地发现相关的编码规范问题,并及时修正。了解更多:https://t.zsxq.com/07KH1zqqs

推荐阅读

  1. 持续交付 2.0
  2. 价值探索环
  3. 快速验证环
  4. 组织文化
  5. 软件系统架构
  6. 需求协作管理
  7. 部署流水线原则
  8. 利于集成的分支策略
目录
相关文章
|
2月前
|
机器学习/深度学习 人工智能 jenkins
软件测试中的自动化与持续集成实践
在快速迭代的软件开发过程中,自动化测试和持续集成(CI)是确保代码质量和加速产品上市的关键。本文探讨了自动化测试的重要性、常见的自动化测试工具以及如何将自动化测试整合到持续集成流程中,以提高软件测试的效率和可靠性。通过案例分析,展示了自动化测试和持续集成在实际项目中的应用效果,并提供了实施建议。
|
2月前
|
jenkins Devops Java
DevOps实践:Jenkins在持续集成与持续部署中的价值
【10月更文挑战第27天】在快速发展的软件开发领域,DevOps实践日益重要。Jenkins作为一款流行的开源自动化服务器,在持续集成(CI)和持续部署(CD)中扮演关键角色。本文通过案例分析,探讨Jenkins在Java项目中的应用,展示其自动化构建、测试和部署的能力,提高开发效率和软件质量。
76 2
|
25天前
|
DataWorks 数据挖掘 大数据
方案实践测评 | DataWorks集成Hologres构建一站式高性能的OLAP数据分析
DataWorks在任务开发便捷性、任务运行速度、产品使用门槛等方面都表现出色。在数据处理场景方面仍有改进和扩展的空间,通过引入更多的智能技术、扩展数据源支持、优化任务调度和可视化功能以及提升团队协作效率,DataWorks将能够为企业提供更全面、更高效的数据处理解决方案。
|
1月前
|
存储 测试技术 持续交付
Docker与CI/CD的集成策略及其对软件开发效率和质量的提升作用
本文探讨了Docker与CI/CD的集成策略及其对软件开发效率和质量的提升作用。首先介绍了CI/CD的基本概念,接着阐述了Docker在环境一致性、快速部署、资源隔离和轻量化方面的优势。文章还详细讨论了构建、测试和部署阶段的具体集成方法,以及集成后带来的效率提升、可靠性增强、加速交付和易于管理等好处。最后,通过案例分析展示了集成的实际效果,强调了Docker与CI/CD结合的重要性和未来前景。
49 2
|
2月前
|
监控 测试技术 持续交付
自动化和持续集成在软件开发中各自扮演什么角色
在软件开发中,自动化与持续集成(CI)相辅相成,共同提升开发效率和软件质量。自动化通过高效执行测试、构建和部署等重复任务,减少人为错误,确保流程一致性,并支持持续部署。CI则通过频繁集成代码变更、提供快速反馈、提高代码质量和促进团队协作,简化部署过程。两者结合,极大优化了软件开发流程。
|
2月前
|
运维 Devops jenkins
DevOps实践:持续集成与持续部署在现代软件开发中的作用
【10月更文挑战第42天】在快节奏的软件开发世界里,DevOps已经成为一种提升效率、确保质量和加速交付的重要方法。本文将深入探讨DevOps的核心组成部分—持续集成(CI)和持续部署(CD)—并展示它们如何通过自动化流程优化开发周期。我们将从基础概念讲起,逐步过渡到实际操作,最终通过一个简单代码示例来演示这一过程。文章旨在为读者提供清晰的指导,帮助他们理解和实现CI/CD流程,从而在软件开发领域取得竞争优势。
|
2月前
|
Devops jenkins 测试技术
DevOps实践:自动化部署与持续集成的融合之旅
【10月更文挑战第41天】在软件开发的世界中,快速迭代和高效交付是企业竞争力的关键。本文将带你走进DevOps的核心实践——自动化部署与持续集成,揭示如何通过它们提升开发流程的效率与质量。我们将从DevOps的基本理念出发,逐步深入到具体的技术实现,最终展示一个实际的代码示例,让理论与实践相结合,为你的开发旅程提供清晰的指引。
61 4
|
2月前
|
监控 测试技术 持续交付
自动化和持续集成在软件开发中各自扮演什么角色?
自动化和持续集成在软件开发中各自扮演什么角色?
|
2月前
|
监控 测试技术 持续交付
自动化和持续集成在软件开发中各自扮演什么角色?
自动化和持续集成在软件开发中各自扮演什么角色?
|
2月前
|
存储 监控 Devops
DevOps实践:持续集成/持续部署(CI/CD)的实战指南
DevOps实践:持续集成/持续部署(CI/CD)的实战指南

热门文章

最新文章