gitlab和gitlab-runner的一个小坑
情况说明:
一台主机上使用yum方式安装的gitlab,使用docker方式安装的gitlab-runner
主机上的/etc/hosts添加了一条自定义的解析域名
192.168.80.201 gitlab.example.com
windows客户端上的hosts文件也添加了这个。
gitlab的配置文件/etc/gitlab/gitlab.rb中有关设置如下
cat /etc/gitlab/gitlab.rb|grep external_url | grep -v "^#"
external_url 'http://gitlab.example.com'
/var/opt/gitlab/gitlab-rails/etc/gitlab.yml
文件中显示的也是
## GitLab settings
gitlab:
## Web server settings (note: host is the FQDN, do not include http://)
host: gitlab.example.com
port: 80
https: false
这样一来的结果是项目中克隆的地址都是使用的gitlab.example.com,同时gitlab-runner上添加的话显示的url地址也是gitlab.example.com
windows客户端上使用浏览器访问这个域名可以打开并登录gitlab上,同时也可以创建项目往gitlab上推送拉取等。
但是结合gitlab-runner使用的时候,新建了一个.gitlab-ci.yml
文件,想实现windows客户端这边提交代码到gitlab上后,直接开始CICD功能。
但是在执行CICD功能的时候,提示没法解析gitlab.example.com这个域名
就算把用容器起来的docker-runner的网络换成host方式,采用宿主机的/etc/hosts配置后还是出现上述同样的问题。
临时解决办法,修改/var/opt/gitlab/gitlab-rails/etc/gitlab.yml
文件中host为gitlab所在主机ip
## GitLab settings
gitlab:
## Web server settings (note: host is the FQDN, do not include http://)
host: 192.168.80.201
port: 80
https: false
这样一来拉取代码的话使用的就是ip地址。
问题分析:
在执行pipeline job的时候,gitlab runner会使用指定的image临时build一个container来执行job,那么首先在container中会先pull你的project的代码,但是使用默认的桥接网络没法访问到gitlab.example.com对应的地址
解决办法:
在gitlab-runner配置文件中添加额外的域名解析,在运行时拉取gitlab上的仓库文件时需要使用的,在 [runners.docker] 下
添加多个的示例:
[runners.docker]
extra_hosts = ["gitlab.example.com:192.168.80.201","jdd.io:192.168.2.162"]
目录 返回
首页