2014-07-28 19:43:00 +02:00
---
2020-08-15 03:51:06 +02:00
layout: "language"
2020-10-27 02:15:36 +01:00
page_title: "Overview - Configuration Language"
2014-07-28 19:43:00 +02:00
---
2020-10-27 02:15:36 +01:00
# Terraform Language Documentation
2014-07-28 19:43:00 +02:00
2020-10-27 02:15:36 +01:00
This is the documentation for Terraform's configuration language. It is relevant
to users of [Terraform CLI ](/docs/cli-index.html ),
[Terraform Cloud ](/docs/cloud/index.html ), and
[Terraform Enterprise ](/docs/enterprise/index.html ).
2019-01-17 01:30:43 +01:00
2020-10-02 20:02:59 +02:00
> **Hands-on:** Try the [Terraform: Get Started](https://learn.hashicorp.com/collections/terraform/aws-get-started?utm_source=WEBSITE&utm_medium=WEB_IO&utm_offer=ARTICLE_PAGE&utm_content=DOCS) collection on HashiCorp Learn.
2020-07-31 22:16:35 +02:00
2020-10-27 02:15:36 +01:00
_The Terraform language is Terraform's primary user interface._ In every edition
of Terraform, a configuration written in the Terraform language is always at the
heart of the workflow.
2018-05-05 22:51:35 +02:00
2020-10-27 02:15:36 +01:00
## About the Terraform Language
2018-05-05 22:51:35 +02:00
2020-10-27 02:15:36 +01:00
The main purpose of the Terraform language is declaring
[resources ](./resources.html ), which represent infrastructure objects. All other
language features exist only to make the definition of resources more flexible
and convenient.
2018-05-05 22:51:35 +02:00
2020-10-27 02:15:36 +01:00
A _Terraform configuration_ is a complete document in the Terraform language
that tells Terraform how to manage a given collection of infrastructure. A
configuration can consist of multiple files and directories.
2018-12-11 01:14:33 +01:00
The syntax of the Terraform language consists of only a few basic elements:
```hcl
resource "aws_vpc" "main" {
cidr_block = var.base_cidr_block
}
< BLOCK TYPE > "< BLOCK LABEL > " "< BLOCK LABEL > " {
# Block body
< IDENTIFIER > = < EXPRESSION > # Argument
}
```
- _Blocks_ are containers for other content and usually represent the
configuration of some kind of object, like a resource. Blocks have a
_block type,_ can have zero or more _labels,_ and have a _body_ that contains
any number of arguments and nested blocks. Most of Terraform's features are
controlled by top-level blocks in a configuration file.
- _Arguments_ assign a value to a name. They appear within blocks.
- _Expressions_ represent a value, either literally or by referencing and
combining other values. They appear as values for arguments, or within other
expressions.
2020-10-27 02:15:36 +01:00
The Terraform language is declarative, describing an intended goal rather than
the steps to reach that goal. The ordering of blocks and the files they are
organized into are generally not significant; Terraform only considers implicit
and explicit relationships between resources when determining an order of
operations.
2018-05-05 22:51:35 +02:00
2020-10-27 02:15:36 +01:00
### Example
2018-05-05 22:51:35 +02:00
2020-10-27 02:15:36 +01:00
The following example describes a simple network topology for Amazon Web
2018-05-05 22:51:35 +02:00
Services, just to give a sense of the overall structure and syntax of the
Terraform language. Similar configurations can be created for other virtual
network services, using resource types defined by other providers, and a
practical network configuration will often contain additional elements not
shown here.
```hcl
2020-07-31 06:07:36 +02:00
terraform {
required_providers {
aws = {
source = "hashicorp/aws"
version = "~> 1.0.4"
}
}
}
2018-05-05 22:51:35 +02:00
variable "aws_region" {}
variable "base_cidr_block" {
description = "A /16 CIDR range definition, such as 10.1.0.0/16, that the VPC will use"
default = "10.1.0.0/16"
}
variable "availability_zones" {
description = "A list of availability zones in which to create subnets"
2018-12-11 01:14:33 +01:00
type = list(string)
2018-05-05 22:51:35 +02:00
}
provider "aws" {
region = var.aws_region
}
resource "aws_vpc" "main" {
# Referencing the base_cidr_block variable allows the network address
# to be changed without modifying the configuration.
cidr_block = var.base_cidr_block
}
resource "aws_subnet" "az" {
# Create one subnet for each given availability zone.
count = length(var.availability_zones)
# For each subnet, use one of the specified availability zones.
availability_zone = var.availability_zones[count.index]
# By referencing the aws_vpc.main object, Terraform knows that the subnet
# must be created only after the VPC is created.
vpc_id = aws_vpc.main.id
# Built-in functions and operators can be used for simple transformations of
# values, such as computing a subnet address. Here we create a /20 prefix for
# each subnet, using consecutive addresses for each availability zone,
# such as 10.1.16.0/20 .
cidr_block = cidrsubnet(aws_vpc.main.cidr_block, 4, count.index+1)
}
```