基于Gitlab的CICD流程

2023-06-02,,

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

1.CICD概述

什么是CICD呢?

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

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

CICD是怎么实现的呢?

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

远程仓库功能
pipeline
runner

基本的流程如下:

码农将代码推送到远程仓库上, 然后触发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分类,等等比较细粒度的规则。

基于Gitlab的CICD流程的相关教程结束。

《基于Gitlab的CICD流程.doc》

下载本文的Word格式文档,以方便收藏与打印。