Gitlab-CI DinD 不会启动

Mik*_* A. 8 gitlab docker gitlab-ci gitlab-ci-runner docker-compose

我正在尝试将 DinD(Docker 中的 Docker)与我的 Gitlab-CI 构建脚本一起使用,无论我更改什么,我都会收到相同的错误。我究竟做错了什么?

错误

Service container logs: 
2018-08-21T22:54:00.129660274Z mount: permission denied (are you root?)
2018-08-21T22:54:00.129701426Z Could not mount /sys/kernel/security.
2018-08-21T22:54:00.129706380Z AppArmor detection and --privileged mode might break.
2018-08-21T22:54:00.130334774Z mount: permission denied (are you root?)
...
$ docker info
error during connect: Get http://docker:2375/v1.38/info: dial tcp: lookup docker on 8.8.8.8:53: no such host
Run Code Online (Sandbox Code Playgroud)

gitlab-ci.yml

django_build:
  stage: build
  variables:
    DOCKER_HOST: tcp://docker:2375/
    DOCKER_DRIVER: overlay2
  image: docker:stable
  services:
    - docker:dind
  before_script:
    - docker info
  script:
    - echo "Building something." 
Run Code Online (Sandbox Code Playgroud)

gitlab-runner config.toml

concurrent = 1 
check_interval = 0 

[[runners]]
  name = "###"
  url = "###"
  token = "###"
  executor = "docker"
  [runners.docker]
    tls_verify = false
    image = "alpine:3.4"
    privileged = true
    disable_cache = false
    volumes = ["/cache"]
  [runners.cache]
    Insecure = false
Run Code Online (Sandbox Code Playgroud)

/etc/docker/daemon.json

{
    "storage-driver": "overlay2"
}
Run Code Online (Sandbox Code Playgroud)

---编辑---

对于任何回来看看这个的人,我是如何让它工作的。在提交到 repo 之前,我在本地机器上运行 gitlab-runner 以测试内容。

运行命令时:

gitlab-runner exec docker django_build
Run Code Online (Sandbox Code Playgroud)

无论出于何种原因,它没有使用我的配置文件。我找到了这个链接:https : //gitlab.com/gitlab-org/gitlab-runner/issues/1791说明你必须在命令中去掉 --docker-privileged

运行后:

gitlab-runner exec docker --docker-privileged django_build
Run Code Online (Sandbox Code Playgroud)

一切正常。

Von*_*onC 3

运行 docker 时仔细检查GitLab 运行器参数。

特别是,请确保将gitlab-runner用户添加到 docker 组:

sudo usermod -aG docker gitlab-runner

从那里开始,sudo -u gitlab-runner -H docker info应该可以工作。

如果没有,请检查是否已/etc/hosts作为卷安装,如本 bug 所示


官方gitlab-runner 文档指出,对于 DiD 执行器,创建一个 config.toml

[[runners]]
  url = "https://gitlab.com/"
  token = TOKEN
  executor = "docker"
  [runners.docker]
    tls_verify = false
    image = "docker:stable"
    privileged = true
Run Code Online (Sandbox Code Playgroud)

但OP发现privileged = true没有使用。
除非 config.tml 是由sudo gitlab-runner register -n... --docker-privileged命令创建的。

如果没有,gitlab-runner exec docker --docker-privileged则需要。