如何使用docker DIND

时间:2019-02-15 10:58:10

标签: docker gitlab gitlab-ci gitlab-ci-runner docker-in-docker

实际上,我正在使用带有docker executor的gitlab运行程序,并且尝试拉一些docker映像进行一些测试,并保留我的网络连接,我创建了一个私有docker注册表来“缓存”图片。

因此,我的注册表已链接到我的gitlab运行程序(通过config.toml https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnersdocker-section中的配置)。

这项工作,我的图像可以询问注册表:

$ wget http://registry:5000/v2/_catalog

--2019-02-15 10:40:54--  http://registry:5000/v2/_catalog
Resolving registry... 172.17.0.3
Connecting to registry|172.17.0.3|:5000... connected.
HTTP request sent, awaiting response... 200 OK
Length: 20 [application/json]
Saving to: '_catalog'

     0K                                                       100% 1.17M=0s

2019-02-15 10:40:54 (1.17 MB/s) - '_catalog' saved [20/20]

但是DIND服务不能:

pull registry:5000/arminc/clair-db:latest
Error response from daemon: Get http://registry:5000/v2/: dial tcp: lookup registry on 192.168.9.254:53: no such host

为此任务我的gitlab-ci conf

scan:image:
  stage: scans
  image: docker:git
  services:
    - name: docker:dind
      command: ["--insecure-registry=registry:5000"]
  variables:
    DOCKER_DRIVER: overlay2
  allow_failure: true
  script:
    - chmod 777 ./docker/scan.sh
    - docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD $DOCKER_REGISTRY
    - ./docker/scan.sh
  artifacts:
    paths: [gl-container-scanning-report.json]
  only:
    - master

0 个答案:

没有答案