持续集成(Continuous integration,简称CI)指的是,频繁地(一天屡次)将代码集成到主干。node
GitLab CI
是 GitLab Continuous Integration
(Gitlab 持续集成)的简称。从 GitLab
的 8.0 版本开始,GitLab
就全面集成了 Gitlab-CI
,而且对全部项目默认开启。只要在项目仓库的根目录添加 .gitlab-ci.yml
文件,而且配置了 Runner
(运行器),那么每一次合并请求(MR)或者 push
都会触发 CI pipeline
。git
若是一切运行正常,你将获得与 commit 关联的标记。如图:github
一次 Pipeline
其实至关于一次构建任务,里面能够包含多个流程,如安装依赖、运行测试、编译、部署测试服务器、部署生产服务器等流程。 任何提交或者 Merge Request 的合并均可以触发 Pipeline
,以下图所示:docker
+------------------+ +----------------+
| | trigger | |
| Commit / MR +---------->+ Pipeline |
| | | |
+------------------+ +----------------+
复制代码
Stages
表示构建阶段,说白了就是上面提到的流程。 咱们能够在一次 Pipeline
中定义多个 Stages
,这些 Stages
会有如下特色:shell
Stages
会按照顺序运行,即当一个 Stage
完成后,下一个 Stage
才会开始Stages
完成后,该构建任务 (Pipeline
) 才会成功Stage
失败,那么后面的 Stages
不会执行,该构建任务 (Pipeline
) 失败所以,Stages
和 Pipeline
的关系就是:npm
+--------------------------------------------------------+
| |
| Pipeline |
| |
| +-----------+ +------------+ +------------+ |
| | Stage 1 |---->| Stage 2 |----->| Stage 3 | |
| +-----------+ +------------+ +------------+ |
| |
+--------------------------------------------------------+
复制代码
Jobs
表示构建工做,表示某个 Stage 里面执行的工做。 咱们能够在 Stages
里面定义多个 Jobs
,这些 Jobs
会有如下特色:vim
Stage
中的 Jobs
会并行执行Stage
中的 Jobs
都执行成功时,该 Stage 才会成功Job
失败,那么该 Stage
失败,即该构建任务 (Pipeline
) 失败因此,Jobs
和 Stage
的关系图就是:ruby
+------------------------------------------+
| |
| Stage 1 |
| |
| +---------+ +---------+ +---------+ |
| | Job 1 | | Job 2 | | Job 3 | |
| +---------+ +---------+ +---------+ |
| |
+------------------------------------------+
复制代码
安装环境为
Ubuntu 16.04.4 LTS (GNU/Linux 4.4.0-105-generic x86_64)
,docker
版本为Docker version 18.03.1-ce, build 9ee9f40
bash
gitlab-ci-multi-runner
# For Debian/Ubuntu
curl -L https://packages.gitlab.com/install/repositories/runner/gitlab-ci-multi-runner/script.deb.sh | sudo bash
# For RHEL/CentOS
curl -L https://packages.gitlab.com/install/repositories/runner/gitlab-ci-multi-runner/script.rpm.sh | sudo bash
复制代码
docker images
sudo docker images
复制代码
.gitlab-ci.yml
文件,文件代码以下:
stages
定义Stages
,默认有三个Stages
,分别是build
,test
,deploy
。Job.only
定义只有develop
分支会触发相关的Jobs
。服务器
stages:
- build
job1:
# 是否开启 debug 模式
# variables:
# CI_DEBUG_TRACE: "true"
stage: build
tags:
- 新建 runner 的标签
only:
- develop
script:
- cd public
- npm i
- npm run build
复制代码
pipeline
配置页面URL
和 Token
,留以注册 runner
使用runner
,runner
注册成功以后,你会在 pipeline
配置页面看见 specific runners
下多出了你刚新增的 runner
。sudo gitlab-ci-multi-runner register
# Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com )
你的 URL
# Please enter the gitlab-ci token for this runner
你的 Token
# Please enter the gitlab-ci description for this runner
my-runner
# Please enter the gitlab-ci tags for this runner (comma separated)
my-runner
Whether to run untagged builds [true/false]:
false
Whether to lock Runner to current project [true/false]:
false
# Please enter the executor: shell, docker, docker-ssh, ssh?
docker
# Please enter the Docker image (eg. ruby:2.1):
node:9.4.0
复制代码
runner
sudo gitlab-ci-multi-runner unregister --url url地址 --token tocken值
复制代码
runner
状态sudo gitlab-ci-multi-runner status
复制代码
runner
列表sudo gitlab-ci-multi-runner list
复制代码
runner
配置文件sudo vim /etc/gitlab-runner/config.toml
复制代码
切换到项目 Pipelines
页面,发现出现如下状况,则表明你的 runner
已经配置完成,你的每一次提交都会触发 runner
。
使用 GitLab CI 克隆私有仓库时候,会提示 Host key verification failed
。
须要作以下配置,Key
写入 SSH_PRIVATE_KEY
,Value
写入 服务器 private SSH key
。而后在 .gitlab-ci.yml
文件前面写入以下代码,并保存。
```powershell
before_script:
- 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client -y )'
# Run ssh-agent (inside the build environment)
- eval $(ssh-agent -s)
# Add the SSH key stored in SSH_PRIVATE_KEY variable to the agent store
- ssh-add <(echo "$SSH_PRIVATE_KEY")
- mkdir -p ~/.ssh
- '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
```
复制代码