Commit 8fd673ff authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

Merge pull request #2364 from tdg5/explicit_docker_pp_sequencing

website: Be more explicit about sequence definition usage in docker builder docs
parents 31357df1 d1961e78
...@@ -117,7 +117,10 @@ _exported_. More specifically, if you set `export_path` in your configuration. ...@@ -117,7 +117,10 @@ _exported_. More specifically, if you set `export_path` in your configuration.
If you set `commit`, see the next section. If you set `commit`, see the next section.
The example below shows a full configuration that would import and push The example below shows a full configuration that would import and push
the created image: the created image. This is accomplished using a sequence definition (a
collection of post-processors that are treated as as single pipeline, see
[Post-Processors](/docs/templates/post-processors.html)
for more information):
```javascript ```javascript
{ {
...@@ -134,6 +137,12 @@ the created image: ...@@ -134,6 +137,12 @@ the created image:
} }
``` ```
In the above example, the result of each builder is passed through the defined
sequence of post-processors starting first with the `docker-import`
post-processor which will import the artifact as a docker image. The resulting
docker image is then passed on to the `docker-push` post-processor which handles
pushing the image to a container repository.
If you want to do this manually, however, perhaps from a script, you can If you want to do this manually, however, perhaps from a script, you can
import the image using the process below: import the image using the process below:
...@@ -146,9 +155,37 @@ and `docker push`, respectively. ...@@ -146,9 +155,37 @@ and `docker push`, respectively.
## Using the Artifact: Committed ## Using the Artifact: Committed
If you committed your container to an image, you probably want to tag, If you committed your container to an image, you probably want to tag, save,
save, push, etc. Packer can do this automatically for you. An example is push, etc. Packer can do this automatically for you. An example is shown below
shown below which tags and pushes the image: which tags and pushes an image. This is accomplished using a sequence
definition (a collection of post-processors that are treated as as single
pipeline, see [Post-Processors](/docs/templates/post-processors.html) for more
information):
```javascript
{
"post-processors": [
[
{
"type": "docker-tag",
"repository": "mitchellh/packer",
"tag": "0.7"
},
"docker-push"
]
]
}
```
In the above example, the result of each builder is passed through the defined
sequence of post-processors starting first with the `docker-tag` post-processor
which tags the committed image with the supplied repository and tag information.
Once tagged, the resulting artifact is then passed on to the `docker-push`
post-processor which handles pushing the image to a container repository.
Going a step further, if you wanted to tag and push an image to multiple
container repositories, this could be accomplished by defining two,
nearly-identical sequence definitions, as demonstrated by the example below:
```javascript ```javascript
{ {
...@@ -160,6 +197,14 @@ shown below which tags and pushes the image: ...@@ -160,6 +197,14 @@ shown below which tags and pushes the image:
"tag": "0.7" "tag": "0.7"
}, },
"docker-push" "docker-push"
],
[
{
"type": "docker-tag",
"repository": "hashicorp/packer",
"tag": "0.7"
},
"docker-push"
] ]
] ]
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment