本片文章主要初步介绍什么是CICD流程,并且把整个流程进行拆分理解整个流程的跑通过程。


1.CICD概述

  • 什么是CICD呢?

简单的说CICD就是持续集成自动构建自动测试自动部署.


从概念上就可以看出,CICD主要由四个部分组成代码集成、打包构建、自动测试、自动部署。我们只需要把代码推送到gitlab远程分支上gitlab自动帮我们做好后面的所有流程,不需要我们手动参与,一看就非常的方便。


  • CICD是怎么实现的呢?

要实现CICD得实现以下几个部分:

  • 远程仓库功能
  • pipeline
  • runner

基本的流程如下:

gitlab ci extends多个job gitlab中cicd_远程仓库

码农将代码推送到远程仓库上, 然后触发pipline流水线通知注册的runner执行pipeline上定义的任务。


2.CI部分

CI就是代码集成也就是阶段性地向代码存库中集成最新的代码,其中gitlab的作用和github等代码托管平台的作用是一模一样的。


3.pipeline

gitlab中pipline翻译过来就是管道,我们知道管道很小水流是顺序流出的,也就是我们定义构建任务,测试任务,部署任务然后任务按照顺序执行,那么如果定义任务呢?

在项目根目录下新建一个 .gitlab-ci.yml 文件,在文件中我们可以定义任务执行阶段,及每个阶段执行的任务等信息,如下代码

before_script:
  - bundle install

after_script:
  - rm secrets

stages:
  - build
  - test
  - deploy

job1:
  stage: build
  script:
    - execute-script-for-job1
  only:
    - master
  tags:
    - docker
job2:
stage: test
script:
  - echo zhe shi ce shi jie daun
  
job3:
stage: deploy
script:
  - echo 这是自动部署阶段

那上面的例子举例,我们就在管道中定义了3个阶段,分别为build、test、deploy三个阶段,然后我们定义job1任务为build阶段执行的,script为执行的命令,job2为test阶段执行的任务,job3为deply阶段执行的任务。

当然真实生产时.gitlab-ci.yml文件肯定比这复杂很多,具体复杂的属性可以根据官方文档查看。


我们定义好了pieline,那么任务的执行者是谁呢?这就是接下来的runner角色了。


4.runner

runner一看名字我们就知道他是我们每个阶段任务的真实执行者,那它是怎么工作的呢?

  • 首先我们需要在需要部署代码的机器上安装runner(不可以和gitlab服务一个机器)
  • 然后启动runner
  • 启动runner程序,并注册到gitlab服务器上(建立runner和gitlab服务器的连接)
  • 选择一个excutor执行方式(比如是shell的本地执行,还是docker容器内执行,还是k8s等方式,初练选shell会好一点就是本地执行)
  • 完成、等待触发


5.总结

我们只需要把整个CICD流程结构化区分一下思路就会瞬间清晰很多了,比如分成提交代码的部分(码农)、远程仓库(gitlab)、定义执行流程(pipeline)、任务执行者(runner)。

然后我们在想一下分成这几个部分以后,整个流程是怎么串起来来的呢?

  • 码农提交代码到远程仓库(我们本地)
  • 触发pipeline任务通知runner去执行(gitlab服务器)
  • runner根据任务阶段顺序执行对应的任务(目标代码部署服务器)


基于上述我们就很快把整个CICD流程给弄清晰了,可以把一些简单的项目执行起来了,

但道路且长,上述只是简单的理解CICD的流程概念,如果需上手真实复杂的项目,还需要阅读官方文档如涉及容器,k8s,不同分支不同runnner,runner分类,excutor分类,等等比较细粒度的规则。