gitlab-runner 注册执行器
前言
上一篇已经讲了 gitlab-runner 的部署方法,这一篇我们来讲一下如何注册 gitlab-runner 并创建作业
一、添加 .gitlab-ci.yml 配置文件
在需要注册 CI/CD 的项目中,增加一个 .gitlab-ci.yml 的配置文件
基本模板配置如下:
1 | |
二、为项目注册 Runner
1. 打开 gitlab 中的需要注册 Runner 的项目
进入 设置 - CI/CD -Runner : 拿到 URL 和 token

2. 在部署 gitlab-runner 的服务器上执行注册指令
1 | |

- 配置步骤详解
1 | |
三、为项目添加执行器
1. runner 注册成功后返回仓库
- 此时页面会新增一条可用的指定 Runner
- 如果此时指示灯是绿色则表示正常

2. 修改设置
- 点击编辑按钮
- 选中 运行未标记的作业
- 确认 启用、未标记的作业、锁定到当前项目都被选中后保存修改

如果不选中 运行未标记的作业, CI/CD 任务会一直被阻塞挂起
此时,即可运行 CI/CD 的作业了。
四、常见问题
1. git clone 地址不正确
这是因为 gitlab 私服部署时会默认使用主机名作为地址
这里需要修改 gitlab URL 的配置,重启后即可生效

2. git clone 连接超时
这里需要检查 gitlab 私服配置的 DNS / IP 地址 / 端口号 是否和外网请求地址一致
这里将上面的 git 仓库地址在浏览器上看看是否能直接打开,即可确认是否是地址有问题

3. 未找到 xxx 命令
这是因为所使用的命令在 runner 服务器上不存在,如:java , node , npm , maven 等
在部署 gitlab-runner 的服务器中安装好开发环境即可。

4. 权限不足
这是因为 gitlab-runner 安装时默认将用户设置为: gitlab-runner.
该设置会使编写的 .gitlab-ci.yml 脚本在命令上收到权限限制问题.
- 可以通过对 gitlab-runner 用户授权 sudo 的方式解决,但是还会有一个问题,就是需要启动服务时显性指定 gitlab-runner 用户,否则 CI/CD 任务不会执行,会一直处队列中。
- 避免麻烦,这里选择使用将 root 用户作为 gitlab-runner 的执行用户

查看gitlab-runner进程:
ps aux | grep gitlab-runner可以查看到 gitlab-runner 的工作目录和默认用户等一系列相关信息。
卸载 gitlab-runner 默认用户:
gitlab-runner uninstall将用户设置为root:
gitlab-runner install --working-directory /home/gitlab-runner --user roott重启服务:
gitlab-runner restart再次查看gitlab-runner进程:
ps aux | grep gitlab-runner

5. docker 中自动化部署build报错

- 检查 docker 是否已经启动
1 | |
- 如果 docker 已启动可能是没有权限导致的,给 docker.sock 增加执行权限
1 | |
6. docker apline temporary error (try again later) 错误
这是因为没有 DNS 导致的
在本机系统上创建daemon文件添加dns,然后重启docker
1 | |