Skip to content

GitLab Runner

Docker-in-Docker

To prevent Ci containers from running as privileged containers the following solution with the rootless-dind setup exists.

GitLab Runner config

  [runners.docker]
    privileged = false
    services_privileged = true
    allowed_privileged_services = ["docker.io/docker:*-dind", "docker.io/library/docker:*-dind-rootless", "docker.io/library/docker:dind-rootless", "docker:*-dind-rootless", "docker:dind-rootless"]
    volumes = ["/certs/client", "/cache"]

GitLab CI config

docker-build:
  services:
    - name: docker.io/docker:24.0.2-dind
      alias: docker
  variables:
    DOCKER_HOST: tcp://docker:2376
    DOCKER_TLS_VERIFY: "true"
    DOCKER_CERT_PATH: "/certs"
    DOCKER_DRIVER: overlay2
  stage: deploy
  script:
    - docker run --rm quay.io/podman/hello:latest