说明

本文简单介绍下 Gitlab CI,包括Gitlab Runner,Gitlab CI中的相关概念以及.gitlab-ci.yml的常用配置。

什么是 GitLab CI

GitLab CI 是GitLab内置的进行持续集成的工具,只需要在仓库根目录下创建.gitlab-ci.yml文件,并配置GitLab Runner;每次提交的时候,gitlab将自动识别到.gitlab-ci.yml文件,并且使用Gitlab Runner执行该脚本。

Gitlab Runner

GitLab-Runner就是一个用来执行.gitlab-ci.yml 脚本的工具。可以理解成,Runner就像认真工作的工人,GitLab-CI就是管理工人的中心,所有工人都要在GitLab-CI里面注册,并且表明自己是为哪个项目服务。当相应的项目发生变化时,GitLab-CI就会通知相应的工人执行对应的脚本。

Runner类型

GitLab-Runner可以分类两种类型:Shared Runner(共享型)Specific Runner(指定型)

(1)Shared Runner:所有工程都能够用的,且只有系统管理员能够创建。

(2)Specific Runner:只有特定的项目可以使用。

Runner搭建

这里提供两种方法(本次使用docker):

(1)For RHEL/CentOS

可参考GitLab Runner官网

curl -L https://packages.gitlab.com/install/repositories/runner/gitlab-ci-multi-runner/script.rpm.sh | sudo bash

(2)使用docker/docker-compose

#获取gitlab-runner 镜像
docker pull gitlab/gitlab-runner:latest
#启动 gitlab-runner
cat docker-compose.yml

version: '2.1'
services:
  gitlab-runner:
    container_name: gitlab-runner
    image: gitlab/gitlab-runner:latest
    restart: always
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
      - ./data/runner_config:/etc/gitlab-runner
      - ./data/git_config/.ssh:/root/.ssh
#定义一个config文件
cd ./data/git_config/.ssh
cat config

Host 192.168.246.198
    StrictHostKeyChecking no

说明:StrictHostKeyChecking no设置免身份认证:在ssh config配置中加一段StrictHostKeyChecking no,如此.gitlab.yml配置中就可以去掉关于known_hosts的设置了;

具体情况可见用GitLab-Runner打造锋利的CI/CD

#启动 gitlab-runner 服务
docker-compose up -d
#进入Runner容器内
docker exec -it gitlab-runner bash

获取Runner注册Token

安装好Runner之后,需要向Gitlab进行注册,注册Runner需要GitLab-CI的url和token。可根据需求注册选择所需类型Runner。

获取Shared Runner注册Token: 使用管理员用户登录,进入Admin Area->OverView->Runners界面。

GitLab ci/cd部署环境构建_第1张图片

获取Specific Runner注册Token: 进行项目仓库->settings->CI/CD界面
GitLab ci/cd部署环境构建_第2张图片

注册Runner

可参考Registering Runners官网

#进入Runner容器内
docker exec -it gitlab-runner bash
#运行以下命令
gitlab-runner register
#输入Gitlab实例的地址
#Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com/):
http://192.168.246.194
#输入token
#Please enter the gitlab-ci token for this runner
zN6snSbddCQkJ7y_ef39
#输入Runner的描述
#Please enter the gitlab-ci description for this runner:
[6c011be28cd8]: ci-test apply
#输入与Runner关联的标签
#Please enter the gitlab-ci tags for this runner (comma separated):
ci-test-tag
#输入Ruuner的执行者
#Please enter the executor: custom, ssh, virtualbox, docker-ssh+machine, kubernetes, docker, docker-ssh, parallels, shell, docker+machine:
docker
#如果上面执行者为docker,需要你在.gitlab-ci.yml中指定docker版本
#Please enter the default Docker image (e.g. ruby:2.6):
alpine:latest

通过以上命令后,就可以在gitlab中查看到了这个刚刚创建的runner:

GitLab ci/cd部署环境构建_第3张图片

修改Runner配置文件

vim /data/gitlab-runner/config/config.toml
#找到volumes配置,修改为如下,分别是挂载了宿主机的docker和配置Maven的缓存,提高效率
volumes = ["/cache","/var/run/docker.sock:/var/run/docker.sock","/data/.m2/:/.m2/"]
#在volumes配置下方增加一行配置,防止Runner重复拉取镜像
pull_policy = "if-not-present"
#重启Runner即可
docker restart gitlab-runner

参考文档

  • GitLab CI介绍——入门篇

  • Docker安装Gitlab和Gitlab-Runner并实现项目CICD