Terraform Associate: Apply Terraform Configuration
data:image/s3,"s3://crabby-images/65755/65755b820f9dce89e012862c38d49ae9c7d90196" alt="Chintan Boghara"
data:image/s3,"s3://crabby-images/99e1d/99e1dcfcc8ae190ec3402aa79ac7ab80f1332979" alt=""
After crafting and reviewing your Terraform plan, the final step in provisioning your infrastructure is to apply the configuration using the terraform apply
command. This command takes your configuration files and the planned changes, then executes the necessary actions to create, modify, or delete resources. Let’s dive into what happens during this process and explore a detailed workflow for applying your Terraform configuration.
What Does terraform apply
Do?
When you run terraform apply
, Terraform performs the following actions:
Recalculates the Desired State:
Terraform reads your configuration files and compares the desired state with the current state stored in your state file (terraform.tfstate
).Executes Necessary Actions:
Based on the differences between the current and desired states, Terraform creates, modifies, or destroys resources to match your configuration.Updates the State File:
Once the changes are made, Terraform updates the state file to reflect the new status of your infrastructure.
This process ensures that your live infrastructure aligns with your configuration, making your deployments predictable and consistent.
Steps to Apply a Terraform Configuration
1. Ensure Terraform Is Initialized
Before applying any changes, make sure your Terraform environment is properly initialized. This ensures that all required provider plugins are installed and the backend is configured.
terraform init
2. Create or Review the Terraform Plan
It’s best practice to run terraform plan
before applying changes. This step previews what Terraform will do and helps you catch any unexpected modifications.
terraform plan
Review the output carefully to understand which resources will be created, modified, or destroyed.
3. Run terraform apply
Once you’re satisfied with the plan, run the following command to apply the configuration:
terraform apply
Terraform will display the execution plan again and prompt for confirmation. You’ll see output similar to:
Terraform will perform the following actions:
# aws_instance.example will be created
+ resource "aws_instance" "example" {
+ ami = "ami-0c55b159cbfafe1f0"
+ id = (known after apply)
+ instance_type = "t2.micro"
+ ...
}
Plan: 1 to add, 0 to change, 0 to destroy.
Do you want to perform these actions?
Only 'yes' will be accepted to approve.
Enter a value:
4. Confirm the Apply Action
Type yes
to confirm and proceed with applying the changes:
Enter a value: yes
If you type anything else, Terraform will cancel the apply operation as a safeguard against accidental modifications.
5. Terraform Applies the Changes
Once confirmed, Terraform executes the necessary actions. You will see progress output indicating the status of each resource, for example:
aws_instance.example: Creating...
aws_instance.example: Still creating... [10s elapsed]
aws_instance.example: Creation complete after 15s [id=i-0a123b4567c89d012]
Apply complete! Resources: 1 added, 0 changed, 0 destroyed.
6. Verify the Infrastructure
After the apply operation completes, verify that the changes have been successfully implemented:
Cloud Provider Dashboard:
Log into the AWS Management Console (or your respective provider’s dashboard) to confirm that the EC2 instance or other resources have been created or updated as expected.State Verification:
Use theterraform show
command to inspect the current state in a human-readable format:terraform show
7. Optional: Apply a Saved Plan
If you previously saved a plan using:
terraform plan -out=tfplan
You can apply the saved plan directly:
terraform apply tfplan
This ensures that the exact set of changes you reviewed is applied to your infrastructure.
Example Workflow: Applying a Terraform Configuration
Let’s review a typical workflow from configuration to deployment:
Write Your Configuration (
main.tf
):provider "aws" { region = "us-west-2" } resource "aws_instance" "example" { ami = "ami-0c55b159cbfafe1f0" instance_type = "t2.micro" }
Initialize the Environment:
terraform init
Generate and Review the Plan:
terraform plan
Apply the Configuration:
terraform apply
Confirm the Changes:
Typeyes
when prompted.Verify the Infrastructure:
Check your AWS console or runterraform show
to review the updated state.
Conclusion
Applying a Terraform configuration using terraform apply
is the final and critical step in the Terraform workflow. It transforms your written configuration into actual infrastructure changes by creating, modifying, or destroying resources, and then updates the state file to reflect these changes. By following the outlined steps—initializing your environment, reviewing the plan, confirming the execution, and verifying the results—you can confidently manage your infrastructure with Terraform.
Happy Terraforming!
Reference
Terraform Apply Command Documentation
Dive into the detailed options and behavior of theterraform apply
command to understand how Terraform implements your configuration changes.Terraform Getting Started Guide
A beginner-friendly guide that walks you through initializing, planning, and applying Terraform configurations in real-world cloud environments.Terraform State Management
Learn how Terraform manages and updates its state file during the apply process, ensuring your infrastructure reflects your configuration accurately.Understanding Terraform Workflow
Explore a complete workflow from configuration to deployment, including the steps to initialize, plan, and apply your Terraform changes.Terraform CLI Commands Overview
Get an overview of all Terraform CLI commands to better understand how each fits into your infrastructure provisioning workflow.
Subscribe to my newsletter
Read articles from Chintan Boghara directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
data:image/s3,"s3://crabby-images/65755/65755b820f9dce89e012862c38d49ae9c7d90196" alt="Chintan Boghara"
Chintan Boghara
Chintan Boghara
Exploring DevOps ♾️, Cloud Computing ☁️, DevSecOps 🔒, Site Reliability Engineering ⚙️, Platform Engineering 🛠️, and Machine Learning Operations 🤖