添加官方仓库
Add the GitLab official repository to your servers package manager.

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

Install the GitLab Runner service.

sudo yum install gitlab-runner

Test that the GitLab Runner is running

sudo service gitlab-runner status

在 GNU/Linux 系统上注册 Runner:

<pre>$ gitlab-runner register</pre>

# 输入 GitLab 实例 URL::[查看地址setting 》CI/CD 》 Runners settings ]

<pre>Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com )
https://gitlab.oneitfarm.com/</pre>

# 输入获取到的用于注册 Runner 的 token:[查看地址setting 》CI/CD 》 Runners settings ]

<pre>Please enter the gitlab-ci token for this runner
xxx</pre>

# 输入该 Runner 的描述,稍后也可通过 GitLab's UI 修改:

<pre>Please enter the gitlab-ci description for this runner
[hostame] xxx</pre>

# [给该 Runner 指派 tags](https://docs.gitlab.com.cn/ce/ci/runners/#using-tags), 稍后也可以在 GitLab's UI 修改: 【tags需要定义,不同的job可以通过tag跑不同的runner】

<pre>Please enter the gitlab-ci tags for this runner (comma separated):
IDG-mamidian</pre>

#选择 Runner 是否接收[未指定 tags](https://docs.gitlab.com.cn/ce/ci/runners/#using-tags) 的任务(默认值:false), 稍后可以在 GitLab's UI 修改:

<pre>Whether to run untagged jobs [true/false]:
[false]: false</pre>

# 选择是否为当前项目锁定该 Runner, 之后也可以在 GitLab's UI 修改。 该功能通常用于被指定为某个项目的 Runner (默认值:true):

<pre>Whether to lock Runner to current project [true/false]:
[true]: true</pre>

# 选择 [Runner executor](https://docs.gitlab.com.cn/runner/executors/README.html):

<pre>Please enter the executor: ssh, docker+machine, docker-ssh+machine, kubernetes, docker, parallels, virtualbox, docker-ssh, shell:
shell</pre>

# 如果你选择 Docker 作为你的 executor,注册程序会让你设置一个默认的镜像, 作用于 .gitlab-ci.yml 中未指定镜像的项目:

<pre>Please enter the Docker image (eg. ruby:2.1):
alpine:latest</pre>

# 注册成功后可在项目页面 》settings 》CI/CD 》Runner setting下看到相关配置,并可一修改runner配置

注意:Tags必填且要唯一

注意,如果是特定项目给个人使用就用Specific Runners ,只有管理员才可以创建共享runner。

GitLab CI 中的基本概念

Runner

配合 GitLab 执行 CI 任务,是实际执行 CI 任务的进程,并将执行结果返回给 GitLab。一般一个项目分配一个 Runner,但也可以多个项目共享一个 Runner。
Executor

执行器,有多种选择,如:docker、shell 等,决定 Runner 以什么环境执行作业,一个 Runner 对应一个 Executor。
Pipline

流水线,流水线代表项目 CI/CD 的整个流程,分为多个阶段(在 .gitlab-ci.yml 中自己规定)。
Stage

阶段,一个 Pipline 对应多个阶段。
Job

CI/CD 中最小的执行单元,一个 Stage 对应多个 Jobs。

实例:

# 流水线分为测试阶段和构建阶段
stages:
  - test
  - build

# 测试作业
test_job:
  stage: test
  image: golang:1.14.2
  tags:
    - demo-project-runner
  services:
    # 执行测试时依赖 MySQL 服务
    - name: mysql:8.0.17
      # golang 容器中可与 mysql 容器通信的别名(内部会 DNS 解析)
      alias: mysql
      command: ['--character-set-server=utf8mb4', '--collation-server=utf8mb4_unicode_ci']
  # 指定作业级变量,会作为环境变量传入 golang 和 mysql 容器
  variables:
    MYSQL_HOST: mysql
    MYSQL_ROOT_PASSWORD: root
    MYSQL_DATABASE: test
  # 执行脚本前的工作,设置 goproxy 加快依赖下载速度
  before_script:
    - go env -w GO111MODULE=on
    - go env -w GOPROXY=https://goproxy.cn,direct
  # 执行代码检查和单元测试
  script:
    - go vet ./...
    - go test -v -race ./...

# 构建作业
build_job:
  stage: build
  image: docker:latest
  
  # services:
  #  - docker:dind
  # variables:
  #   DOCKER_DRIVER: overlay2
  #   DOCKER_TLS_CERTDIR: ''
  
  script:
    # 可将一些变量放在 GitLab 项目设置里,防止密码被包含在代码中
    - docker build -t goapp:latest .
    - docker login -u $DOCKER_REGISTRY_USERNAME -p $DOCKER_REGISTRY_PASSWORD $DOCKER_REGISTRY_ADDR
    - docker tag goapp:latest ${DOCKER_REGISTRY_ADDR}/xvrzhao/goapp:latest
    - docker push ${DOCKER_REGISTRY_ADDR}/xvrzhao/goapp:latest
  tags:
    - demo-project-runner
  # 指定 master 分支的提交才会触发该作业
  only:
    - master