CI持续集成理论知识

时间:2020-12-31 20:21:00 来源:互联网 作者: 神秘的大神 字体:

(1)什么是CI

What is CI?

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

*PS:把企业中的一系列过程集成在CI平台上,可以写好脚本,点击执行,或者定时执行。

CD就是持续交付,是在CI的基础进行了扩展,在CI环节完成了软件构建和测试工作并形成了新的版本,那么接下来就要进行交付,而这里的交付并不是交付到生产环境,而是类生产环境,我们可以理解为灰度环境或者预发环境,进而接受部分真实流量的测试,如果没有问题则通过手动的方式部署到生产环境。

CI常用的工具:Jenkins

工作流:

开发->提交代码->静态代码扫描(直接通过工具去检查代码中的错误)->单元测试->编译->测试->发布

Jenkins是什么?(是一种CI工具)

Jenkins是一个独立的开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。前身是Hudson,是一个可扩展的持续集成引擎。可用于自动化各种任务,如构建,测试和部署软件

  • 主要用于

    • 持续、自动地构建项目、测试软件项目等。

      主要提供了基于版本管理工具(如CVS、VSS、SVN)感知变化每天定时的持续集成,并提供持续集成报告Email(提供丰富的插件库)等方式通知相关负责人,其要求是需要进行日构建的项目已经编写好全自动的项目编译脚本(可基于Maven或Ant)。

    • 监控一些定时执行的任务。

Jenkins特点

  • 开源免费
  • 跨平台,支持所有的平台(Linux、mac、windows)
  • 支持分布式的build(可以在jenkins上建多个自动化脚本,比如一个跑冒烟测试、一个跑回归测试)
  • web形式的可视化的管理页面
  • 安装配置超简单
  • tips提示快速的帮助
  • 已经有很多的插件(比如:Email Extension、Git、GitHub、Subversion)

(2)CI的价值

  1. 减少风险

    越早发现的错误,修正的费用越低。

    及时检查软件测试的健康状况,减少发布时的风险。

    (比如:每天定时触发自动化测试项目,自动生成报告)

  2. 减少重复性的工作

    通过自动化的持续集成可以将编译、部署、测试等动作都变成自动化的,无需太多人工干预。

  3. 任何时间,任何地点都可以部署软件

    利用持续集成,可以经常对源代码进行一些小改动,并将这些改动和其他的代码进行集成。如果出现问题,项目成员马上就会被通知到。

(3)CI的架构

image-20201225224753398