packer-cn/website/source/docs/provisioners/shell-local.html.md

48 lines
1.4 KiB
Markdown
Raw Normal View History

2015-06-19 18:31:17 -04:00
---
2017-06-14 21:04:16 -04:00
description: |
The shell Packer provisioner provisions machines built by Packer using shell
scripts. Shell provisioning is the easiest way to get software installed and
configured on a machine.
2015-08-03 14:32:54 -04:00
layout: docs
2017-06-14 21:04:16 -04:00
page_title: 'Shell (Local) - Provisioners'
sidebar_current: 'docs-provisioners-shell-local'
---
2015-06-19 18:31:17 -04:00
# Local Shell Provisioner
Type: `shell-local`
2015-08-03 14:32:54 -04:00
The local shell provisioner executes a local shell script on the machine running
Packer. The [remote shell](/docs/provisioners/shell.html) provisioner executes
shell scripts on a remote machine.
2015-06-19 18:31:17 -04:00
## Basic Example
The example below is fully functional.
2017-06-14 21:04:16 -04:00
``` json
2015-06-19 18:31:17 -04:00
{
"type": "shell-local",
"command": "echo foo"
}
```
## Configuration Reference
The reference of available configuration options is listed below. The only
required element is "command".
Required:
2017-06-14 21:04:16 -04:00
- `command` (string) - The command to execute. This will be executed within
2015-08-03 14:32:54 -04:00
the context of a shell as specified by `execute_command`.
2015-06-19 18:31:17 -04:00
Optional parameters:
2017-06-14 21:04:16 -04:00
- `execute_command` (array of strings) - The command to use to execute
the script. By default this is `["/bin/sh", "-c", "{{.Command}}"]`. The value
2015-08-03 14:32:54 -04:00
is an array of arguments executed directly by the OS. The value of this is
treated as [configuration
2017-03-28 18:28:34 -04:00
template](/docs/templates/engine.html). The only available
2015-08-03 14:32:54 -04:00
variable is `Command` which is the command to execute.