2016-11-13 00:50:28 -06:00
|
|
|
---
|
|
|
|
layout: "docs"
|
|
|
|
page_title: "Configuring Terraform"
|
|
|
|
sidebar_current: "docs-config-terraform"
|
|
|
|
description: |-
|
2016-11-13 00:52:27 -06:00
|
|
|
The `terraform` configuration section is used to configure Terraform itself, such as requiring a minimum Terraform version to execute a configuration.
|
2016-11-13 00:50:28 -06:00
|
|
|
---
|
|
|
|
|
|
|
|
# Terraform Configuration
|
|
|
|
|
|
|
|
The `terraform` configuration section is used to configure Terraform itself,
|
|
|
|
such as requiring a minimum Terraform version to execute a configuration.
|
|
|
|
|
|
|
|
This page assumes you're familiar with the
|
|
|
|
[configuration syntax](/docs/configuration/syntax.html)
|
|
|
|
already.
|
|
|
|
|
|
|
|
## Example
|
|
|
|
|
|
|
|
Terraform configuration looks like the following:
|
|
|
|
|
2017-04-05 10:29:27 -05:00
|
|
|
```hcl
|
2016-11-13 00:50:28 -06:00
|
|
|
terraform {
|
2017-04-05 10:29:27 -05:00
|
|
|
required_version = "> 0.7.0"
|
2016-11-13 00:50:28 -06:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
## Description
|
|
|
|
|
|
|
|
The `terraform` block configures the behavior of Terraform itself.
|
|
|
|
|
2017-05-29 00:58:08 -05:00
|
|
|
The currently only allowed configurations within this block are
|
|
|
|
`required_version` and `backend`.
|
|
|
|
|
|
|
|
`required_version` specifies a set of version constraints
|
2016-12-15 05:53:41 -06:00
|
|
|
that must be met to perform operations on this configuration. If the
|
2016-11-13 00:50:28 -06:00
|
|
|
running Terraform version doesn't meet these constraints, an error
|
|
|
|
is shown. See the section below dedicated to this option.
|
|
|
|
|
2017-05-29 00:58:08 -05:00
|
|
|
See [backends](/docs/backends/index.html) for more detail on the `backend`
|
|
|
|
configuration.
|
|
|
|
|
2016-11-13 00:50:28 -06:00
|
|
|
**No value within the `terraform` block can use interpolations.** The
|
|
|
|
`terraform` block is loaded very early in the execution of Terraform
|
|
|
|
and interpolations are not yet available.
|
|
|
|
|
|
|
|
## Specifying a Required Terraform Version
|
|
|
|
|
|
|
|
The `required_version` setting can be used to require a specific version
|
|
|
|
of Terraform. If the running version of Terraform doesn't match the
|
|
|
|
constraints specified, Terraform will show an error and exit.
|
|
|
|
|
|
|
|
When [modules](/docs/configuration/modules.html) are used, all Terraform
|
|
|
|
version requirements specified by the complete module tree must be
|
|
|
|
satisified. This means that the `required_version` setting can be used
|
|
|
|
by a module to require that all consumers of a module also use a specific
|
|
|
|
version.
|
|
|
|
|
|
|
|
The value of this configuration is a comma-separated list of constraints.
|
|
|
|
A constraint is an operator followed by a version, such as `> 0.7.0`.
|
|
|
|
Constraints support the following operations:
|
|
|
|
|
2017-04-05 10:29:27 -05:00
|
|
|
- `=` (or no operator): exact version equality
|
|
|
|
|
|
|
|
- `!=`: version not equal
|
|
|
|
|
|
|
|
- `>`, `>=`, `<`, `<=`: version comparison, where "greater than" is a larger
|
|
|
|
version number
|
|
|
|
|
|
|
|
- `~>`: pessimistic constraint operator. Example: for `~> 0.9`, this means
|
|
|
|
`>= 0.9, < 1.0`. Example: for `~> 0.8.4`, this means `>= 0.8.4, < 0.9`
|
2016-11-13 00:50:28 -06:00
|
|
|
|
|
|
|
For modules, a minimum version is recommended, such as `> 0.8.0`. This
|
|
|
|
minimum version ensures that a module operates as expected, but gives
|
|
|
|
the consumer flexibility to use newer versions.
|
|
|
|
|
|
|
|
## Syntax
|
|
|
|
|
|
|
|
The full syntax is:
|
|
|
|
|
2017-04-05 10:29:27 -05:00
|
|
|
```text
|
2016-11-13 00:50:28 -06:00
|
|
|
terraform {
|
2017-04-05 10:29:27 -05:00
|
|
|
required_version = VALUE
|
2016-11-13 00:50:28 -06:00
|
|
|
}
|
|
|
|
```
|