讲了 Docker 的使用,这篇同样通过一个简单示例,来讲讲 。
一、什么是 GitLab CI ?
gitlab-ci 全称是 gitlab continuous integration,也就是基于 gitlab 的持续集成工具。中心思想是当每一次
push到gitlab的时候,都会触发一次脚本执行,然后脚本的内容包括了测试,编译,部署等一系列自定义的内容。高版本的 GitLab 自带了 GitLab CI,所以不需要另外安装。二、什么是 GitLab-Runner ?
GitLab-Runner 是脚本执行的承载者,GitLab-CI 事先注册好 GitLab-Runner,再 push 代码,对应的 Runner 就会执行你所定义的脚本。
三、安装 GitLab-Runner
Gitlab Runner安装方式有两种,一种是直接二进制文件安装,一种是基于docker镜像安装。
二进制文件安装
[1] 下载对应操作系统的二进制包,我这里使用的是mac版本,
sudo curl --output /usr/local/bin/gitlab-ci-multi-runner https://gitlab-ci-multi-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-ci-multi-runner-darwin-amd64
[2] 给 gitlab-ci-multi-runner 设置权限
sudo chmod +x /usr/local/bin/gitlab-ci-multi-runner
以上是官方安装文档,如果有问题,可以手动到下载对应的版本,然后复制到/usr/local/bin/
目录下 ---- 反正我是自己下载安装才能用的,泪目 T T
[3] 注册runner
首先,进入到你的 gitlab 项目网页,找到 Settings -> Pipelines,然后找到对应的 url 和 token然后在终端输入
gitlab-ci-multi-runner register
然后刷新你的网页,会看到
说明注册成功了。
另外,我们可以通过 gitlab-ci-multi-runner list
查询你注册的runner ,用 gitlab-ci-multi-runner status
查看 runner 服务是否运行中。
docker镜像安装
[1] 先获取 gitlab-runner 镜像
sudo docker pull gitlab/gitlab-runner:latest
[2] 启动 gitlab-runner container
sudo docker run -d --name gitlab-runner --restart always \ -v /srv/gitlab-runner/config:/etc/gitlab-runner \ -v /var/run/docker.sock:/var/run/docker.sock \ gitlab/gitlab-runner:latest
[3] 注册runner
sudo docker exec -it gitlab-runner gitlab-ci-multi-runner register注册过程略,方式同方式一步骤3.
四、配置.gitlab-ci.yml
GitLab CI的一切工作,都是由 .gitlab-ci.yml 来配置的。详细文档可以参考
首先,在项目根目录下创建 .gitlab-ci.yml 文件(编辑完要提交到g itlab 才能生效):
#定义 stages,用来定义工作阶段,多个 stages 会按顺序进行stages: - build - deploy_test - deploy_production# 设置缓存 cache: paths: - node_modules/ - dist/# 安装依赖 before_script 会在每个 stages 执行之前运行before_script:- npm install# 编译 这里对应上方 stages ,build: stage: build script: # script 为要执行的命令,可以多条按顺序执行 - npm run build# 部署测试服务器 deploy_test: stage: deploy_test only: # only 定义触发分支,即只有在dev分支提交是 才执行以下命令 - dev script: - bash scripts/dev.sh# 部署生产服务器deploy_production: stage: deploy_production only: - master script: - bash scripts/deploy.sh
配置完成后,当你在项目 push 代码到 gitlab 的时候,就会触发 gitlab-ci,然后执行你定义的代码。
可以在running 表示正在运行,passed 表示通过了。
ps:有个容易遇到的坑,当你卡在 pending 不动的时候,可以看看你的 runner 是否设置了 '无 tag 标签也运行'回到你的 runner,点编辑然后,勾选第二项 Run untagged jobs
运行日志可以在这里查看
那么到这,GitLab CI 的基本使用,已经完成啦,赶快去试一下吧 :)
参考资料: