Packer docker builder在docker image中配置docker

时间:2019-04-17 14:50:14

标签: docker build packer docker-in-docker

我正在尝试使用Packer设置docker:dind映像,它将构建另一个docker映像,并使用以下构建脚本在docker内部运行它:

{
  "builders": [
    {
      "type": "docker",
      "image": "docker:dind",
      "privileged": true,
      "commit": "true"
    }
  ],
  "provisioners": [
    {
      "type": "file",
      "source": "../docker/",
      "destination": "/docker"
    },
    {
      "type": "shell",
      "inline": [
        "docker build -t my-service /docker"
      ]
    }
  ],
  "post-processors": [
    [
      {
        "type": "docker-tag",
        "repository": "my-service",
        "tag": "latest"
      }
    ]
  ]
}

当我运行此脚本时,它失败并显示以下错误:

$ packer build build.json
docker output will be in this color.

==> docker: Creating a temporary directory for sharing data...
==> docker: Pulling Docker image: docker:dind
    docker: dind: Pulling from library/docker
    docker: Digest: sha256:21fe82c6e54e2db31e64f79ec7ac75c6a8f7469cdc56687ced97d6fc3e75e6cd
    docker: Status: Image is up to date for docker:dind
==> docker: Starting docker container...
    docker: Run command: docker run --privileged -v C:\Users\user\packer.d\tmp:/packer-files -d -i -t --entrypoint=/bin/sh -- docker:dind
    docker: Container ID: 7fa2ae91eaf6111ce6d0567f1e523100c777311449454b0df8d6d49c84c477d6
==> docker: Using docker communicator to connect: 172.17.0.2
==> docker: Uploading ../docker/ => /docker
==> docker: Provisioning with shell script: C:\Users\user\AppData\Local\Temp\packer-shell164551847
==> docker: Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
==> docker: Killing the container: 7fa2ae91eaf6111ce6d0567f1e523100c777311449454b0df8d6d49c84c477d6
Build 'docker' errored: Script exited with non-zero exit status: 1.Allowed exit codes are: [0]

==> Some builds didn't complete successfully and had errors:
--> docker: Script exited with non-zero exit status: 1.Allowed exit codes are: [0]

==> Builds finished but no artifacts were created.

问题在于,打包程序启动容器时,它将覆盖默认入口点[“ dockerd-entrypoint.sh”],该入口点是在docker:dind映像中使用其自己的入口点[“ / bin / sh”]配置的。这样可以防止docker进程内部的docker启动并且无法执行shell脚本。

我尝试使用以下选项更改入口点和run_command,但是在第一种情况下,它没有任何作用(我认为它将在提交映像时在末尾进行更新),而在后者中,它无法执行任何脚本。 / p>

"changes": [
  "ENTRYPOINT [dockerd-entrypoint.sh]"
],
"run_command": ["-d", "-i", "-t", "--entrypoint=dockerd-entrypoint.sh", "--", "{{.Image}}"]

另一种选择是运行“ [dockerd-entrypoint.sh]”作为内嵌shell脚本(第一个),但这阻止了该过程并且不执行后续步骤。

我的选件用完了,我需要一些帮助来了解它的工作原理以及是否有解决方案。

1 个答案:

答案 0 :(得分:0)

在您的inline部分中,首先使用诸如dockerd-entrypoint.sh & sleep 5之类的东西在后台运行docker daemon。