`
kidiaoer
  • 浏览: 822041 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

如何进行持续集成?

阅读更多
如何进行持续集成?

    在进行持续集成实践前,应当正确的选择并配置持续集成服务器。列出了所有的持续集成服务器 ,其中比较成熟的持续集成服务器包括:CruiseControl, Anthill, Bamboo, TeamCity, Continuum 等。CruiseControl作为开源产品,以其对于各种SCM以及构建工具的广泛支持而被许多开发团队所接受。

    在一个典型的持续集成过程中:

    - 开发者每次将代码提交到SVN之前,必须运行本地测试: 尽量保证不会破坏持续集成服务器的构建过程。

    - 开发者每天进行多次提交:小步前进会大大减少服务器构建失败的概率,并且使得修复失败构建的时间大大缩短。

    - 持续集成在一台服务器上不断运行:保证在稳定的环境中进行测试。

    - 所有的测试必须全部通过:保证软件现有的功能不被破坏并且没有引入新的缺陷

    - 生成构建结果(War, Jar,exe等) : 用以开展下一步的工作,譬如QA的探索测试等。

    - 生成报表 :帮助管理人员评估开发状态。

    - 修复失败的构建 : 失败的构建意味着软件现有的功能已经被破坏或者有新的缺陷被引入,修复的速度越慢使修复难度越高,并带来更大的损失。

    持续集成坏味道:

    - 持续编译

    [现象]某些团队仅仅使用持续集成服务进行编译并生成最终的构建结果。

    [影响]持续集成无法给开发人员,管理人员带来有价值的快速反馈。

    [原因]开发团队可能缺乏编写易于测试的代码的能力,或者不了解现代软件开发中测试的流程和作用

    [解决方案]测试优先,单元测试,功能测试,验收测试

    - 构建长时间失败

    [现象] 没有开发者愿意修复失败的构建,持续集成工具上的构建已经持续失败很长时间。

    [影响] 开发者忽视持续集成服务器发布的结果,修复构建的成本和难度升高,开发团队,管理团队无法得到快速反馈,丧失安全感

    [原因] 长时间不进行代码更新并一次提交太多代码,构建时间太长导致开发者缺乏耐心运行本地构建、任务过于复杂

    [解决方案] 简单设计,小步前进,缩短构建时间

    - 过多失败构建

    [现象]持续集成服务器上有很多失败的构建、开发者常常在持续集成服务器上强制运行构建

    [影响]团队其它成员无法提交代码,开发效率下降。

    [原因] 通常这是项目中存在随机失败测试的信号,譬如,某些测试存在顺序依赖,时间敏感或者没有在测试结束时正确回收资源。这样,虽然开发者本地构建通过,却无法保证在持续集成服务器上成功构建,开发者会不断的尝试在服务器端重新运行构建试图得到一个成功的构建

    [解决方案] 简单设计,编写正确的单元测试

    - 构建时间过长

    [现象]本地构建时间超过10分钟

    [影响]生产率严重下降

    [原因] 可能是由于重复测试引起,由于测试之间没有很好的隔离,导致同一逻辑在对不同对象进行测试时被重复测试、或者是软件规模大,测试多引起

    [解决方案] 分布式构建

    - 构建结果不醒目

    [现象] 没有开发者意识到持续集成服务器上的构建已经失败了

    [影响] 构建长时间失败,修复难度变大

    [原因] 没有将构建结果明显的发布出来

    [解决方案] 安装构建指示灯,或者在构建失败的时候播放音乐。

    拥抱持续集成:

    为了享受持续集成带来的诸多好处,开发者需要做到:

    - 小步前进,频繁提交

    - 不要提交本地测试失败的代码

    - 编写可以自动进行的测试

    - 编写可以快速运行的测试

    - 如果构建失败,第一时间进行修复

    - 如果构建失败,拒绝更新代码
分享到:
评论

相关推荐

    java持续集成 持续集成

    Java持续集成是软件开发过程中的一个关键实践,它旨在频繁地合并开发人员的代码更改,以便尽早发现并解决潜在的问题。这个过程通过自动化构建、测试和部署,确保代码的质量和项目的稳定性。持续集成(Continuous ...

    持续集成php持续集成

    在持续集成环境中,Selenium_IDE可以辅助进行功能测试,确保应用程序的功能在每次更新后仍然正常工作。它可以生成可移植的Selenium测试脚本,这些脚本可以在不同环境和浏览器上运行,以验证软件的兼容性和稳定性。 ...

    持续集成软件质量改进和风险降低之道.pdf

    《持续集成:软件质量改进和风险降低之道》一书深入探讨了如何在IT行业中通过持续集成来提升软件质量并有效管理风险。持续集成是敏捷开发方法的重要组成部分,它强调频繁地将开发人员的工作成果合并到主分支,以尽早...

    企业IT持续集成与持续交付实践.pdf

    企业IT持续集成与持续交付实践 持续集成(Continuous Integration,CI)和持续交付(Continuous Delivery,CD)是企业IT实践中两个非常重要的概念,它们之间紧密相连,都是为了提高软件开发、测试和部署的效率和...

    持续集成、交付和部署:对方法、工具、挑战和实践的系统回顾.pdf

    持续集成、交付和部署(CI/CD)是软件开发行业中的实践方法,其目标是使组织能够更频繁、更可靠地发布新的特性和产品。随着对持续实践方法兴趣的增加,系统性地回顾和总结这些实践方法、工具、挑战和实践的做法变得...

    持续集成持续集成持续集成

    持续集成持续集成持续集成持续集成持续集成持续集成持续集成

    走向“持续部署”

    ”已经不再是讨论的焦点,取而代之的是“如何进行持续集成?”。在前一篇文章中,我介绍了Cruise团队持续集成的演进过程。在最后,还曾提  目前IT行业中,似乎“要不要做持续集成?”已经不再是讨论的焦点,取而代之...

    jenkins+jmeter持续集成.pdf

    总结:以上知识点涉及了从安装和配置JDK、JMeter到Jenkins的完整流程,以及如何将JMeter集成到Jenkins中进行持续集成和接口测试。文档中还提到了Ant的安装和Jenkins插件管理,以及Jenkins安全性设置的相关操作。这些...

    持续集成配置文件

    持续集成工具 cruisecontrol 配置文件

    持续集成实践

    持续集成实践作为软件开发领域的一项重要实践,是保障软件开发质量、提高开发效率的重要手段。该实践强调开发团队成员频繁地集成他们的工作成果,通常每人每天至少集成一次,从而尽早发现和解决问题,减少集成的...

    PHP持续集成实践

    PHP持续集成是软件开发过程中的一个重要环节,它强调在开发过程中频繁地集成代码,并通过自动化的方式进行编译、测试和质量检查,以尽早发现并修复问题,提升软件的质量和稳定性。本实践主要围绕jenkins、sonar、...

    持续集成的几个步骤

    持续集成(Continuous Integration,简称CI)是一种软件开发实践,它要求开发人员频繁地(通常是每天多次)将代码更改集成到共享的主干中。这个实践的重点在于尽早和频繁地检测到集成错误,确保项目开发的各个分支...

    持续集成aci3.pdf

    通过以上介绍可以看出,利用Hudson进行基于Subversion的持续集成不仅可以显著提高开发效率,还能有效提升代码质量。通过自动化构建和测试,开发者可以专注于编写高质量的代码,而不用担心集成问题。此外,Hudson还...

    jenkins持续集成Loadrunner

    jenkins持续集成Loadrunner jenkins是一款流行的持续集成工具,而Loadrunner是一款功能强大的性能测试工具。将Loadrunner集成到jenkins中,可以实现自动化的性能测试,提高测试效率和测试覆盖率。本文将详细介绍...

Global site tag (gtag.js) - Google Analytics