Packer Docker Builder: настроить оболочку для запуска Docker? - PullRequest
1 голос
/ 07 марта 2019

Я хочу предоставить образ докера с помощью докера и ansible.Я хочу использовать альпийский как базовое изображение.Некоторые образы докеров, такие как Alpine, не предоставляют "/ bin / bash".Когда упаковщик запускает этот образ докера, он продолжает запускать / bin / bash.Это приведет к сбою процесса сборки:

dockerbuild.json:

{
  "builders": [
    {
      "type": "docker",
      "image": "alpine:3.8",
      "commit": true
    }
  ],
  "provisioners": [
    {
      "type": "ansible",
      "user": "root",
      "playbook_file": "playbook.yml",
      "extra_arguments": [
        "--extra-vars",
        "ansible_connection=docker"
      ]
    }
  ]
}

Ошибка:

$> packer build dockerbuild.json
...
==> docker: Starting docker container...
    docker: Run command: docker run -v /Users/engi/.packer.d/tmp/packer-docker014300196:/packer-files -d -i -t alpine:3.8 /bin/bash
==> docker: Error running container: Docker exited with a non-zero exit status.
==> docker: Stderr: docker: Error response from daemon: OCI runtime create failed: container_linux.go:344: starting container process caused "exec: \"/bin/bash\": stat /bin/bash: no such file or directory": unknown.

Я могу запустить образ вручную с помощью "/ bin / sh"или без явной оболочки:

docker run --rm -i -t alpine:3.8 /bin/sh
docker run --rm -i -t alpine:3.8

Вы знаете, как я могу указать упаковщику не запускать / bin / bash?

1 Ответ

1 голос
/ 07 марта 2019

Я нашел решение в документации (удивление): run_command

https://www.packer.io/docs/builders/docker.html

Это сработало для меня:

{
  "builders": [
    {
      "type": "docker",
      "image": "alpine:3.8",
      "commit": true,
      "run_command": ["-d", "-i", "-t", "{{.Image}}", "/bin/sh"]
    }
  ],
  "provisioners": [
    {
      "type": "ansible",
      "user": "root",
      "playbook_file": "playbook.yml",
      "extra_arguments": [
        "--extra-vars",
        "ansible_connection=docker"
      ]
    }
  ]
}
...