88 lines
3.4 KiB
Markdown
88 lines
3.4 KiB
Markdown
---
|
|
layout: "docs"
|
|
page_title: "Templates"
|
|
---
|
|
|
|
# Templates
|
|
|
|
Templates are JSON files that configure the various components of Packer
|
|
in order to create one or more machine images. Templates are portable, static,
|
|
and readable and writable by both humans and computers. This has the added
|
|
benefit of being able to not only create and modify templates by hand, but
|
|
also write scripts to dynamically create or modify templates.
|
|
|
|
Templates are given to commands such as `packer build`, which will
|
|
take the template and actually run the builds within it, producing
|
|
any resulting machine images.
|
|
|
|
## Template Structure
|
|
|
|
A template is a JSON object that has a set of keys configuring various
|
|
components of Packer. The available keys within a template are listed below.
|
|
Along with each key, it is noted whether it is required or not.
|
|
|
|
* `builders` (_required_) is an array of one or more objects that defines
|
|
the builders that will be used to create machine images for this template,
|
|
and configures each of those builders. For more information on how to define
|
|
and configure a builder, read the sub-section on
|
|
[configuring builders in templates](/docs/templates/builders.html).
|
|
|
|
* `description` (optional) is a string providing a description of what
|
|
the template does. This output is used only in the
|
|
[inspect command](/docs/command-line/inspect.html).
|
|
|
|
* `min_packer_version` (optional) is a string that has a minimum Packer
|
|
version that is required to parse the template. This can be used to
|
|
ensure that proper versions of Packer are used with the template. A
|
|
max version can't be specified because Packer retains backwards
|
|
compatibility with `packer fix`.
|
|
|
|
* `post-processors` (optional) is an array of one or more objects that defines the
|
|
various post-processing steps to take with the built images. If not specified,
|
|
then no post-processing will be done. For more
|
|
information on what post-processors do and how they're defined, read the
|
|
sub-section on [configuring post-processors in templates](/docs/templates/post-processors.html).
|
|
|
|
* `provisioners` (optional) is an array of one or more objects that defines
|
|
the provisioners that will be used to install and configure software for
|
|
the machines created by each of the builders. If it is not specified,
|
|
then no provisioners will be run. For more
|
|
information on how to define and configure a provisioner, read the
|
|
sub-section on [configuring provisioners in templates](/docs/templates/provisioners.html).
|
|
|
|
* `variables` (optional) is an array of one or more key/value strings that defines
|
|
user variables contained in the template.
|
|
If it is not specified, then no variables are defined.
|
|
For more information on how to define and use user variables, read the
|
|
sub-section on [user variables in templates](/docs/templates/user-variables.html).
|
|
|
|
## Example Template
|
|
|
|
Below is an example of a basic template that is nearly fully functional. It is just
|
|
missing valid AWS access keys. Otherwise, it would work properly with
|
|
`packer build`.
|
|
|
|
<pre class="prettyprint">
|
|
{
|
|
"builders": [
|
|
{
|
|
"type": "amazon-ebs",
|
|
"access_key": "...",
|
|
"secret_key": "...",
|
|
"region": "us-east-1",
|
|
"source_ami": "ami-de0d9eb7",
|
|
"instance_type": "t1.micro",
|
|
"ssh_username": "ubuntu",
|
|
"ami_name": "packer {{timestamp}}"
|
|
}
|
|
],
|
|
|
|
"provisioners": [
|
|
{
|
|
"type": "shell",
|
|
"script": "setup_things.sh"
|
|
}
|
|
]
|
|
}
|
|
</pre>
|