2013-11-09 16:28:00 -05:00
|
|
|
---
|
|
|
|
layout: "docs"
|
|
|
|
---
|
|
|
|
|
|
|
|
# Docker Builder
|
|
|
|
|
|
|
|
Type: `docker`
|
|
|
|
|
|
|
|
The Docker builder builds [Docker](http://www.docker.io) images using
|
|
|
|
Docker. The builder starts a Docker container, runs provisioners within
|
|
|
|
this container, then exports the container for re-use.
|
|
|
|
|
2013-11-09 22:40:38 -05:00
|
|
|
Packer builds Docker containers _without_ the use of
|
|
|
|
[Dockerfiles](http://docs.docker.io/en/latest/use/builder/).
|
|
|
|
By not using Dockerfiles, Packer is able to provision
|
|
|
|
containers with portable scripts or configuration management systems
|
|
|
|
that are not tied to Docker in any way. It also has a simpler mental model:
|
|
|
|
you provision containers much the same way you provision a normal virtualized
|
|
|
|
or dedicated server. For more information, read the section on
|
2013-12-31 14:00:08 -05:00
|
|
|
[Dockerfiles](#toc_4).
|
2013-11-09 22:40:38 -05:00
|
|
|
|
|
|
|
The Docker builder must run on a machine that has Docker installed. Therefore
|
|
|
|
the builder only works on machines that support Docker (modern Linux machines).
|
|
|
|
If you want to use Packer to build Docker containers on another platform,
|
|
|
|
use [Vagrant](http://www.vagrantup.com) to start a Linux environment, then
|
|
|
|
run Packer within that environment.
|
2013-11-09 16:28:00 -05:00
|
|
|
|
|
|
|
## Basic Example
|
|
|
|
|
|
|
|
Below is a fully functioning example. It doesn't do anything useful, since
|
|
|
|
no provisioners are defined, but it will effectively repackage an image.
|
|
|
|
|
|
|
|
<pre class="prettyprint">
|
|
|
|
{
|
|
|
|
"type": "docker",
|
|
|
|
"image": "ubuntu",
|
|
|
|
"export_path": "image.tar"
|
|
|
|
}
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
## Configuration Reference
|
|
|
|
|
2013-12-25 05:17:37 -05:00
|
|
|
Configuration options are organized below into two categories: required and
|
|
|
|
optional. Within each category, the available options are alphabetized and
|
|
|
|
described.
|
2013-11-09 20:22:39 -05:00
|
|
|
|
2014-05-04 13:47:40 -04:00
|
|
|
### Required:
|
2013-11-09 16:28:00 -05:00
|
|
|
|
|
|
|
* `export_path` (string) - The path where the final container will be exported
|
|
|
|
as a tar file.
|
|
|
|
|
|
|
|
* `image` (string) - The base image for the Docker container that will
|
|
|
|
be started. This image will be pulled from the Docker registry if it
|
|
|
|
doesn't already exist.
|
|
|
|
|
2014-05-04 13:47:40 -04:00
|
|
|
### Optional:
|
2013-11-09 20:22:39 -05:00
|
|
|
|
2014-05-04 13:47:40 -04:00
|
|
|
* `pull` (boolean) - If true, the configured image will be pulled using
|
2013-11-09 20:22:39 -05:00
|
|
|
`docker pull` prior to use. Otherwise, it is assumed the image already
|
|
|
|
exists and can be used. This defaults to true if not set.
|
|
|
|
|
2013-12-27 12:17:45 -05:00
|
|
|
* `run_command` (array of strings) - An array of arguments to pass to
|
|
|
|
`docker` in order to run the container. By default this is set to
|
|
|
|
`["run", "-d", "-i", "-t", "-v", "{{.Volumes}}", "{{.Image}}", "/bin/bash"]`.
|
|
|
|
As you can see, you have a couple template variables to customize, as well.
|
|
|
|
|
2014-01-19 23:42:42 -05:00
|
|
|
## Using the Artifact
|
2013-12-24 20:40:13 -05:00
|
|
|
|
2013-12-25 05:17:37 -05:00
|
|
|
Once the tar artifact has been generated, you will likely want to import, tag,
|
2014-01-19 23:42:42 -05:00
|
|
|
and push it to a container repository. Packer can do this for you automatically
|
|
|
|
with the [docker-import](/docs/post-processors/docker-import.html) and
|
|
|
|
[docker-push](/docs/post-processors/docker-push.html) post-processors.
|
2013-12-24 20:40:13 -05:00
|
|
|
|
2014-01-19 23:42:42 -05:00
|
|
|
The example below shows a full configuration that would import and push
|
|
|
|
the created image:
|
|
|
|
|
|
|
|
<pre class="prettyprint">
|
|
|
|
{
|
|
|
|
"post-processors": [
|
|
|
|
[
|
2014-01-19 23:48:03 -05:00
|
|
|
{
|
|
|
|
"type": "docker-import",
|
|
|
|
"repository": "mitchellh/packer",
|
|
|
|
"tag": "0.7"
|
|
|
|
},
|
2014-01-19 23:42:42 -05:00
|
|
|
"docker-push"
|
|
|
|
]
|
|
|
|
]
|
|
|
|
}
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
If you want to do this manually, however, perhaps from a script, you can
|
|
|
|
import the image using the process below:
|
|
|
|
|
|
|
|
docker import - registry.mydomain.com/mycontainer:latest < artifact.tar
|
2013-12-24 20:40:13 -05:00
|
|
|
|
2013-12-25 05:17:37 -05:00
|
|
|
You can then add additional tags and push the image as usual with `docker tag`
|
|
|
|
and `docker push`, respectively.
|
2013-12-24 20:40:13 -05:00
|
|
|
|
2013-11-09 16:28:00 -05:00
|
|
|
## Dockerfiles
|
|
|
|
|
2013-11-09 22:40:38 -05:00
|
|
|
This builder allows you to build Docker images _without_ Dockerfiles.
|
2013-11-09 16:59:34 -05:00
|
|
|
|
2014-07-21 20:56:19 -04:00
|
|
|
With this builder, you can repeatably create Docker images without the use of
|
2013-11-09 16:59:34 -05:00
|
|
|
a Dockerfile. You don't need to know the syntax or semantics of Dockerfiles.
|
|
|
|
Instead, you can just provide shell scripts, Chef recipes, Puppet manifests,
|
2013-11-09 22:40:38 -05:00
|
|
|
etc. to provision your Docker container just like you would a regular
|
|
|
|
virtualized or dedicated machine.
|
|
|
|
|
|
|
|
While Docker has many features, Packer views Docker simply as an LXC
|
|
|
|
container runner. To that end, Packer is able to repeatably build these
|
|
|
|
LXC containers using portable provisioning scripts.
|
|
|
|
|
|
|
|
Dockerfiles have some additional features that Packer doesn't support
|
|
|
|
which are able to be worked around. Many of these features will be automated
|
|
|
|
by Packer in the future:
|
|
|
|
|
|
|
|
* Dockerfiles will snapshot the container at each step, allowing you to
|
|
|
|
go back to any step in the history of building. Packer doesn't do this yet,
|
|
|
|
but inter-step snapshotting is on the way.
|
|
|
|
|
|
|
|
* Dockerfiles can contain information such as exposed ports, shared
|
|
|
|
volumes, and other metadata. Packer builds a raw Docker container image
|
|
|
|
that has none of this metadata. You can pass in much of this metadata
|
|
|
|
at runtime with `docker run`.
|