2013-06-08 17:36:22 -04:00
---
2015-07-22 22:31:00 -04:00
layout: docs
page_title: Templates
2017-03-25 18:13:52 -04:00
sidebar_current: docs-templates
description: |-
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.
---
2013-06-08 17:36:22 -04:00
# Templates
2015-07-22 22:31:00 -04:00
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.
2013-06-08 17:36:22 -04:00
2015-07-22 22:31:00 -04:00
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.
2013-06-08 17:36:22 -04:00
## 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.
2017-03-25 18:13:52 -04:00
- `builders` (*required*) is an array of one or more objects that defines the
2015-07-22 23:25:58 -04:00
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).
2015-07-22 22:31:00 -04:00
2017-03-25 18:13:52 -04:00
- `description` (optional) is a string providing a description of what the
2015-07-22 23:25:58 -04:00
template does. This output is used only in the [inspect
2017-03-25 18:13:52 -04:00
command](/docs/commands/inspect.html).
2015-07-22 22:31:00 -04:00
2017-03-25 18:13:52 -04:00
- `min_packer_version` (optional) is a string that has a minimum Packer
2015-07-22 23:25:58 -04:00
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` .
2015-07-22 22:31:00 -04:00
2017-03-25 18:13:52 -04:00
- `post-processors` (optional) is an array of one or more objects that defines
2015-07-22 23:25:58 -04:00
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).
2015-07-22 22:31:00 -04:00
2017-03-25 18:13:52 -04:00
- `provisioners` (optional) is an array of one or more objects that defines
2015-07-22 23:25:58 -04:00
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).
2015-07-22 22:31:00 -04:00
2017-03-25 18:13:52 -04:00
- `variables` (optional) is an object of one or more key/value strings that
2015-07-22 23:25:58 -04:00
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).
2014-05-04 13:47:40 -04:00
2015-06-13 16:19:25 -04:00
## Comments
JSON doesn't support comments and Packer reports unknown keys as validation
2015-07-22 22:31:00 -04:00
errors. If you'd like to comment your template, you can prefix a *root level*
2015-06-13 16:19:25 -04:00
key with an underscore. Example:
2017-03-25 18:13:52 -04:00
```json
2015-06-13 16:19:25 -04:00
{
"_comment": "This is a comment",
2017-03-25 18:13:52 -04:00
"builders": [
{}
]
2015-06-13 16:19:25 -04:00
}
```
2015-07-22 22:31:00 -04:00
**Important:** Only *root level* keys can be underscore prefixed. Keys within
2015-06-13 16:19:25 -04:00
builders, provisioners, etc. will still result in validation errors.
2013-06-08 17:36:22 -04:00
## Example Template
2016-02-16 16:49:38 -05:00
Below is an example of a basic template that could be invoked with `packer build` . It would create an instance in AWS, and once running copy a script to it and run that script using SSH.
2017-03-25 18:13:52 -04:00
-> **Note:** This example requires an account with Amazon Web Services. There are a number of parameters which need to be provided for a functional build to take place. See the [Amazon builder ](/docs/builders/amazon.html ) documentation for more information.
2013-06-08 17:36:22 -04:00
2017-03-25 18:13:52 -04:00
```json
2013-06-08 17:36:22 -04:00
{
"builders": [
{
"type": "amazon-ebs",
"access_key": "...",
"secret_key": "...",
"region": "us-east-1",
2016-03-16 22:28:10 -04:00
"source_ami": "ami-fce3c696",
2016-01-13 16:52:17 -05:00
"instance_type": "t2.micro",
2013-06-08 17:36:22 -04:00
"ssh_username": "ubuntu",
2013-08-08 20:01:33 -04:00
"ami_name": "packer {{timestamp}}"
2013-06-08 17:36:22 -04:00
}
],
"provisioners": [
{
"type": "shell",
2013-07-05 08:42:22 -04:00
"script": "setup_things.sh"
2013-06-08 17:36:22 -04:00
}
]
}
2014-10-20 13:55:16 -04:00
```