packer-cn/website/pages/docs/templates/post-processors.mdx

178 lines
6.3 KiB
Plaintext
Raw Normal View History

---
2017-06-14 21:04:16 -04:00
description: |
2020-03-18 18:46:47 -04:00
The post-processor section within a template configures any post-processing
that will be done to images built by the builders. Examples of post-processing
would be compressing files, uploading artifacts, etc.
2015-07-22 22:31:00 -04:00
layout: docs
2020-03-18 18:46:47 -04:00
page_title: Post-Processors - Templates
sidebar_title: Post-Processors
---
# Template Post-Processors
2018-10-26 20:02:51 -04:00
The post-processor section within a template configures any post-processing
that will be done to images built by the builders. Examples of post-processing
would be compressing files, uploading artifacts, etc.
2020-03-18 18:46:47 -04:00
Post-processors are _optional_. If no post-processors are defined within a
2015-07-22 22:31:00 -04:00
template, then no post-processing will be done to the image. The resulting
artifact of a build is just the image outputted by the builder.
This documentation page will cover how to configure a post-processor in a
template. The specific configuration options available for each post-processor,
2015-07-22 22:31:00 -04:00
however, must be referenced from the documentation for that specific
post-processor.
Within a template, a section of post-processor definitions looks like this:
```json
{
"post-processors": [
// ... one or more post-processor definitions here
]
}
```
For each post-processor definition, Packer will take the result of each of the
2018-10-26 20:02:51 -04:00
defined builders and send it through the post-processors. This means that if
you have one post-processor defined and two builders defined in a template, the
post-processor will run twice (once for each builder), by default. There are
ways, which will be covered later, to control what builders post-processors
2019-02-20 05:47:39 -05:00
apply to, if you wish. It is also possible to prevent a post-processor from
running.
## Post-Processor Definition
2018-10-26 20:02:51 -04:00
Within the `post-processors` array in a template, there are three ways to
2020-03-18 18:46:47 -04:00
define a post-processor. There are _simple_ definitions, _detailed_
definitions, and _sequence_ definitions. Another way to think about this is
2018-10-26 20:02:51 -04:00
that the "simple" and "detailed" definitions are shortcuts for the "sequence"
definition.
A **simple definition** is just a string; the name of the post-processor. An
2015-07-22 22:31:00 -04:00
example is shown below. Simple definitions are used when no additional
configuration is needed for the post-processor.
```json
{
"post-processors": ["compress"]
}
```
2015-07-22 22:31:00 -04:00
A **detailed definition** is a JSON object. It is very similar to a builder or
provisioner definition. It contains a `type` field to denote the type of the
post-processor, but may also contain additional configuration for the
post-processor. A detailed definition is used when additional configuration is
2018-10-26 20:02:51 -04:00
needed beyond simply the type for the post-processor. An example is shown
below.
```json
{
"post-processors": [
{
"type": "compress",
"format": "tar.gz"
}
]
}
```
A **sequence definition** is a JSON array comprised of other **simple** or
2015-07-22 22:31:00 -04:00
**detailed** definitions. The post-processors defined in the array are run in
order, with the artifact of each feeding into the next, and any intermediary
artifacts being discarded. A sequence definition may not contain another
sequence definition. Sequence definitions are used to chain together multiple
post-processors. An example is shown below, where the artifact of a build is
compressed then uploaded, but the compressed result is not kept.
2018-10-26 20:02:51 -04:00
It is very important that any post processors that need to be run in order, be
sequenced!
```json
{
"post-processors": [
2020-03-18 18:46:47 -04:00
["compress", { "type": "upload", "endpoint": "http://example.com" }]
]
}
```
2015-07-22 22:31:00 -04:00
As you may be able to imagine, the **simple** and **detailed** definitions are
simply shortcuts for a **sequence** definition of only one element.
2013-06-27 11:25:12 -04:00
## Input Artifacts
2018-10-26 20:02:51 -04:00
When using post-processors, the input artifact (coming from a builder or
another post-processor) is discarded by default after the post-processor runs.
This is because generally, you don't want the intermediary artifacts on the way
to the final artifact created.
2013-06-27 11:25:12 -04:00
2018-10-26 20:02:51 -04:00
In some cases, however, you may want to keep the intermediary artifacts. You
can tell Packer to keep these artifacts by setting the `keep_input_artifact`
2015-07-22 22:31:00 -04:00
configuration to `true`. An example is shown below:
2013-06-27 11:25:12 -04:00
```json
2013-06-27 11:25:12 -04:00
{
"post-processors": [
{
"type": "compress",
"keep_input_artifact": true
}
]
}
```
2013-06-27 11:25:12 -04:00
2020-03-18 18:46:47 -04:00
This setting will only keep the input artifact to _that specific_
2015-07-22 22:31:00 -04:00
post-processor. If you're specifying a sequence of post-processors, then all
intermediaries are discarded by default except for the input artifacts to
post-processors that explicitly state to keep the input artifact.
2013-06-27 11:25:12 -04:00
2020-03-23 20:02:12 -04:00
-> **Note:** The intuitive reader may be wondering what happens if multiple
2015-07-22 22:31:00 -04:00
post-processors are specified (not in a sequence). Does Packer require the
configuration to keep the input artifact on all the post-processors? The answer
is no, of course not. Packer is smart enough to figure out that at least one
post-processor requested that the input be kept, so it will keep it around.
2013-09-20 14:42:25 -04:00
## Run on Specific Builds
2019-02-20 05:47:39 -05:00
You can use the `only` or `except` fields to run a post-processor only with
specific builds. These two fields do what you expect: `only` will only run the
post-processor on the specified builds and `except` will run the post-processor
on anything other than the specified builds. A sequence of post-processors will
execute until a skipped post-processor.
2013-09-20 14:42:25 -04:00
2015-07-22 22:31:00 -04:00
An example of `only` being used is shown below, but the usage of `except` is
effectively the same. `only` and `except` can only be specified on "detailed"
2019-02-20 05:47:39 -05:00
fields. If you have a sequence of post-processors to run, `only` and `except`
will affect that post-processor and stop the sequence.
2019-02-20 06:34:52 -05:00
The `-except` option can specifically skip a named post processor. The `-only`
2020-03-18 18:46:47 -04:00
option _ignores_ post-processors.
2013-09-20 14:42:25 -04:00
```json
2020-03-18 18:46:47 -04:00
([
2019-02-20 05:47:39 -05:00
{
2019-02-20 06:34:52 -05:00
// can be skipped when running `packer build -except vbox`
2019-02-20 05:47:39 -05:00
"name": "vbox",
"type": "vagrant",
"only": ["virtualbox-iso"]
},
{
"type": "compress" // will only be executed when vbox is
}
],
[
"compress", // will run even if vbox is skipped, from the same start as vbox.
{
"type": "upload",
"endpoint": "http://example.com"
}
// this list of post processors will execute
// using build, not another post-processor.
2020-03-18 18:46:47 -04:00
])
```
2013-09-20 14:42:25 -04:00
2020-03-18 18:46:47 -04:00
The values within `only` or `except` are _build names_, not builder types. If
2015-07-22 22:31:00 -04:00
you recall, build names by default are just their builder type, but if you
2018-10-26 20:02:51 -04:00
specify a custom `name` parameter, then you should use that as the value
instead of the type.