Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
packer
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kristopher Ruzic
packer
Commits
0449add7
Commit
0449add7
authored
Jun 08, 2013
by
Mitchell Hashimoto
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
website: template provisioner docs
parent
1676befc
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
87 additions
and
1 deletion
+87
-1
website/source/docs/templates/provisioners.html.markdown
website/source/docs/templates/provisioners.html.markdown
+86
-0
website/source/layouts/docs.erb
website/source/layouts/docs.erb
+1
-1
No files found.
website/source/docs/templates/provisioners.html.markdown
0 → 100644
View file @
0449add7
---
layout
:
"
docs"
---
# Templates: Provisioners
Within the template, the provisioners section contains an array of all the
provisioners that Packer should use to install and configure software within
running machines prior to turning them into machine images.
Provisioners are _optional_. If no provisioners are defined within a template,
then no software other than the defaults will be installed within the
resulting machine images. This is not typical, however, since much of the
value of Packer is to produce multiple identical images
of pre-configured software.
This documentation page will cover how to configure a provisioner in a template.
The specific configuration options available for each provisioner, however,
must be referenced from the documentation for that specific provisioner.
Within a template, a section of provisioner definitions looks like this:
<pre
class=
"prettyprint"
>
{
"provisioners": [
... one or more provisioner definitions here ...
]
}
</pre>
## Provisioner Definition
A provisioner definition is a JSON object that must contain at least
the
`type`
key. This key specifies the name of the provisioner to use.
Additional keys within the object are used to configure the provisioner,
with the exception of a handful of special keys, covered later.
As an example, the "shell" provisioner requires at least the
`path`
key,
which specifies a path to a shell script to execute within the machines
being created.
An example provisioner definition is shown below, configuring the shell
provisioner to run a local script within the machines:
<pre
class=
"prettyprint"
>
{
"type": "shell",
"path": "script.sh"
}
</pre>
## Build-Specific Overrides
While the goal of Packer is to produce identical machine images, it
sometimes requires periods of time where the machines are different before
they eventually converge to be identical. In these cases, different configurations
for provisioners may be necessary depending on the build. This can be done
using build-specific overrides.
An example of where this might be necessary is when building both an EC2 AMI
and a VMware machine. The source EC2 AMI may setup a user with administrative
privileges by default, whereas the VMware machine doesn't have these privileges.
In this case, the shell script may need to be executed differently. Of course,
the goal is that hopefully the shell script converges these two images to be
identical. However, they may initially need to be run differently.
This example is shown below:
<pre
class=
"prettyprint"
>
{
"type": "shell",
"path": "script.sh",
"override": {
"vmware": {
"execute_command": "echo 'password' | sudo -S bash {{.Path}}"
}
}
}
</pre>
As you can see, the
`override`
key is used. The value of this key is another
JSON object where the key is the name of a
[
builder definition
](
/docs/templates/builders.html
)
.
The value of this is in turn another JSON object. This JSON object simply
contains the provisioner configuration as normal. This configuration is merged
into the default provisioner configuration.
website/source/layouts/docs.erb
View file @
0449add7
...
@@ -37,7 +37,7 @@
...
@@ -37,7 +37,7 @@
<li
class=
"nav-header"
>
Templates
</li>
<li
class=
"nav-header"
>
Templates
</li>
<li><a
href=
"/docs/templates/introduction.html"
>
Introduction
</a></li>
<li><a
href=
"/docs/templates/introduction.html"
>
Introduction
</a></li>
<li><a
href=
"/docs/templates/builders.html"
>
Builders
</a></li>
<li><a
href=
"/docs/templates/builders.html"
>
Builders
</a></li>
<li><a
href=
"
#
"
>
Provisioners
</a></li>
<li><a
href=
"
/docs/templates/provisioners.html
"
>
Provisioners
</a></li>
<li
class=
"nav-header"
>
Builders
</li>
<li
class=
"nav-header"
>
Builders
</li>
<li><a
href=
"#"
>
EC2 (AMI)
</a></li>
<li><a
href=
"#"
>
EC2 (AMI)
</a></li>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment