packer-cn/website/source/docs/templates/builders.html.md

77 lines
2.7 KiB
Markdown
Raw Normal View History

2013-06-08 20:11:56 -04:00
---
2017-06-14 21:04:16 -04:00
description: |
2018-10-26 20:02:51 -04:00
Within the template, the builders section contains an array of all the builders
that Packer should use to generate machine images for the template.
2015-07-22 22:31:00 -04:00
layout: docs
2017-06-14 21:04:16 -04:00
page_title: 'Builders - Templates'
sidebar_current: 'docs-templates-builders'
---
2013-06-08 20:11:56 -04:00
# Template Builders
2013-06-08 20:11:56 -04:00
2015-07-22 22:31:00 -04:00
Within the template, the builders section contains an array of all the builders
2018-09-28 21:38:29 -04:00
that Packer should use to generate machine images for the template.
2013-06-08 20:11:56 -04:00
2015-07-22 22:31:00 -04:00
Builders are responsible for creating machines and generating images from them
2018-10-26 20:02:51 -04:00
for various platforms. For example, there are separate builders for EC2,
VMware, VirtualBox, etc. Packer comes with many builders by default, and can
also be extended to add new builders.
2013-06-08 20:11:56 -04:00
2018-10-26 20:02:51 -04:00
This documentation page will cover how to configure a builder in a template.
The specific configuration options available for each builder, however, must be
2015-07-22 22:31:00 -04:00
referenced from the documentation for that specific builder.
2013-06-08 20:11:56 -04:00
Within a template, a section of builder definitions looks like this:
2017-06-14 21:04:16 -04:00
``` json
2013-06-08 20:11:56 -04:00
{
"builders": [
// ... one or more builder definitions here
2013-06-08 20:11:56 -04:00
]
}
```
2013-06-08 20:11:56 -04:00
## Builder Definition
2015-07-22 22:31:00 -04:00
A single builder definition maps to exactly one
[build](/docs/basics/terminology.html#term-build). A builder definition is a
JSON object that requires at least a `type` key. The `type` is the name of the
builder that will be used to create a machine image for the build.
2013-06-08 20:11:56 -04:00
2018-10-26 20:02:51 -04:00
In addition to the `type`, other keys configure the builder itself. For
example, the AWS builder requires an `access_key`, `secret_key`, and some other
settings. These are placed directly within the builder definition.
2013-06-08 20:11:56 -04:00
2015-07-22 22:31:00 -04:00
An example builder definition is shown below, in this case configuring the AWS
builder:
2013-06-08 20:11:56 -04:00
2017-06-14 21:04:16 -04:00
``` json
2013-06-08 20:11:56 -04:00
{
"type": "amazon-ebs",
"access_key": "...",
"secret_key": "..."
}
```
2013-06-08 20:11:56 -04:00
## Named Builds
2015-07-22 22:31:00 -04:00
Each build in Packer has a name. By default, the name is just the name of the
builder being used. In general, this is good enough. Names only serve as an
indicator in the output of what is happening. If you want, however, you can
specify a custom name using the `name` key within the builder definition.
2013-06-08 20:11:56 -04:00
2015-07-22 22:31:00 -04:00
This is particularly useful if you have multiple builds defined that use the
same underlying builder. In this case, you must specify a name for at least one
of them since the names must be unique.
2015-06-23 17:39:29 -04:00
## Communicators
Every build is associated with a single
2015-07-22 22:31:00 -04:00
[communicator](/docs/templates/communicator.html). Communicators are used to
establish a connection for provisioning a remote machine (such as an AWS
instance or local virtual machine).
2015-06-23 17:39:29 -04:00
2015-07-22 22:31:00 -04:00
All the examples for the various builders show some communicator (usually SSH),
but the communicators are highly customizable so we recommend reading the
2015-06-23 17:39:29 -04:00
[communicator documentation](/docs/templates/communicator.html).