GitLab runner在运行管道时无法解析主机

dan*_*ast 7 gitlab docker gitlab-ci-runner docker-compose

我有一个dockerized GitLab和GitLab Runner安装,包括docker-compose.yml:

version: "3"

services:
  gitlab:
    image: gitlab/gitlab-ee:latest
    container_name: gitlab
    restart: always
    hostname: gitlab
    ports:
      - "45022:22"
      - "45080:80"
      - "45443:443"
    volumes:
      - /srv/gitlab/config:/etc/gitlab
      - /srv/gitlab/logs:/var/log/gitlab
      - /srv/gitlab/data:/var/opt/gitlab

  python-runner:
    image: gitlab/gitlab-runner:latest
    container_name: python-runner
    hostname: python-runner
    volumes:
      - /srv/python-runner/config:/etc/gitlab-runner
      - /var/run/docker.sock:/var/run/docker.sock
    environment:
      - CI_SERVER_URL=http://gitlab/ci
      - RUNNER_TOKEN=myTokenCode
      - RUNNER_DESCRIPTION=Python 2.7.14
      - RUNNER_EXECUTOR=docker
      - DOCKER_IMAGE=python:2.7.14
    restart: always
Run Code Online (Sandbox Code Playgroud)

我已经注册了跑步者:

docker exec -it python-runner gitlab-runner register \
    --non-interactive \
    --url "http://gitlab/" \
    --registration-token "${GITLAB_REGISTRATION_TOKEN}" \
    --description "Python 2.7.14" \
    --executor "docker" \
    --docker-image python:2.7.14
Run Code Online (Sandbox Code Playgroud)

跑步者列在跑步者列表中:

在此输入图像描述

我可以通过以下方式ping gitlab主机python-runner:

» docker exec -it python-runner bash
root@python-runner:/# ping gitlab
PING gitlab (172.20.0.2) 56(84) bytes of data.
64 bytes from gitlab.gitlab_default (172.20.0.2): icmp_seq=1 ttl=64 time=0.112 ms
64 bytes from gitlab.gitlab_default (172.20.0.2): icmp_seq=2 ttl=64 time=0.055 ms
^C
--- gitlab ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 999ms
rtt min/avg/max/mdev = 0.055/0.083/0.112/0.029 ms
Run Code Online (Sandbox Code Playgroud)

但是在运行管道时,它会失败:

`fatal: unable to access 'http://gitlab-ci-token:xxxxxxxxxxxxxxxxxxxx@gitlab/group/project.git/': Could not resolve host: gitlab
Run Code Online (Sandbox Code Playgroud)

这怎么可能?怎么解决这个问题?

编辑

我正在创建的架构似乎如下:

  • gitlab在docker gitlab容器中运行
  • 在docker python-runner容器中运行的gitlab runner
  • docker-compose创建一个私有网络gitlab_default(gitlab是项目的名称),gitlab并且python-runner容器和容器都可以通过IP和名称来访问它.
  • python-runner采用docker执行CI中产卵的容器(在主机?),基于python:2.7.14所定义的.我不知道gitlab如何命名这些容器,让我们称之为ci-job
  • ci-job通过发布一个项目克隆在这个容器中git clone.这失败是因为ci-job容器无法到达gitlab容器,因为它可能位于不同的网络中(default网络?)

我试图通过使用flag 强制python-runner在同一gitlab_default网络中生成容器,--docker-network-mode gitlab_default如下所示:

docker exec -it python-runner gitlab-runner register \
    --non-interactive \
    --tag-list python-2.7.14 \
    --url "http://gitlab" \
    --registration-token "$(GITLAB_REGISTRATION_TOKEN)" \
    --name "Python 2.7.14" \
    --executor "docker" \
    --docker-image python:2.7.14 \
    --docker-network-mode gitlab_default
Run Code Online (Sandbox Code Playgroud)

但它仍然无效.我不确定这是否是正确的旗帜,因为它的记录很少.

两个问题:

  1. 运行CI时,如何查看执行程序正在创建的容器?我可以输入它们并在那里进行一些调试吗?
  2. 确保docker执行程序生成的容器与容器位于同一网络中的相关参数是什么gitlab

EDIT2

经过一段空闲时间后,我的工作开始了.似乎配置--docker-network-mode确实按预期工作.

小智 4

我遇到了同样的问题,gitlab-runner 无法解析主机名。但我们使用在 Debian 服务器上运行的 Gitlab(不是 docker 安装)以及通过 VPN 连接的 Google Cloud 中的运行器。

对我有用的是将 dns 地址添加到 runners config.toml 中,如下所示:

  [runners.docker]
    dns = ["dns-1-ip", "dns-2-ip"]
Run Code Online (Sandbox Code Playgroud)