持续集成

  • 持续集成是什么?
  • 为什么要使用持续集成?
  • 持续交付
  • 为什么要交给质量团队或是用户呢?
  • 持续部署
  • 持续集成的流程


持续集成是什么?

CI,是指在一段时间内(如:约定好的一天内或是一个上午),多次的将代码提交到主干上去。自然,每次都要通过测试。

大师Martin Fowler对持续集成是这样定义的:持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽快地发现集成错误。许多团队发现这个过程可以大大减少集成的问题,让团队能够更快的开发内聚的软件。

持续集成实现方案 持续集成概念_持续集成

为什么要使用持续集成?

  • 减少风险
    可以快速的发现错误
  • 可快速定位错误
  • 可降低代码整合的错误
  • 防止长时间过后,集成失败
  • 可以更好的了解进度,更好的收集数据

emmm~~博主表示很难受,在之前的开发之中,打算将所有功能完善之后才去Pull代码、Commit代码以及Push的时候,突然发现。。。。悲剧了
代码拉下来冲突一堆
为了时间问题,当时就是直接重新拉取代码,再去移动新功能代码

继续拿,大师Martin Fowler的话来讲就是,持续集成并不解决BUG,而是能够更加快速的发现以及更正。

自然地,当我们持续集成的时候,必须也要保证代码的可行性,简单讲就是单元测试通过了,我们才去集成。不然就是搞事情了~~~

与持续集成相关的,一般还会搭上持续交付以及持续部署

持续交付

持续交付(Continuous delivery)指的是,频繁地将软件的新版本,交付给质量团队或者用户。持续交付强调的是,无论如何更新,都可以随时随地的交付软件的。

持续集成实现方案 持续集成概念_持续交付_02


过程简单来说就是:

当集成完成以后,可以自动的部署到测试环境当中,而后进入类生产环境中 当一切都经过持续集成后,没问题的时候,我们再手动部署到生成环境。

为什么要交给质量团队或是用户呢?

开句玩笑话的话,那就是,大部分开发人员在完成功能的时候表面看似波澜不惊,一望无垠。但是,内心却是风起云涌。
为什么? 很简单,因为是我们自己写的,所以,基本上找不出反驳自己的问题,但是就是有问题。。。。就是找不出来 尴尬

这时候,就需要专业的质量团队(测试人员)或是用户了。

因为一个是专业的嘛,另一个就是那句话了 ,群众的眼睛是雪亮雪亮的~~BinlingBinling

持续集成实现方案 持续集成概念_持续集成_03

持续部署

  • 持续部署(continuousdeployment)是持续交付的下一步,指的是代码通过评审测试以后,自动部署到生产环境。【图片的AUTO 交付是手动的】
  • 持续部署的目标是,代码在任何时刻都是可部署的,可以进入生产阶段。
  • 持续部署的前提是能自动化完成测试、构建、部署等步骤。

持续集成实现方案 持续集成概念_持续交付_04

持续集成的流程

  • 提交
    如,我们经常的使用开发工具将代码,提交到版本控制系统(GitHub/GitLab)当中。 版本控制系统请移步此处点击
  • 测试
    如,单元测试以及集成测试。
  • 构建
    所谓构建,指的是将源码转换为可以运行的实际代码,比如安装依赖,配置各种资源(样式表、JS脚本、图片)等等。

常用的构建工具如下:

  • Jenkins
  • Travis
  • Codeship
  • Strider
  1. 再一次测试
    此次,测试可以是说是全面性的测试,或是为了减少问题的行为。只为,此次集成的可行性。覆盖率一般大于第一次的测试。
  2. 部署
    打包,将此次版本发布于服务器上。
  3. 回滚
    如果出现问题,即刻,恢复到上个版本。