As you embark on your journey into Infrastructure as Code (IaC) with Terraform, the first crucial step is setting up Terraform on your local machine. In this guide, we'll walk through the installation process and initial configuration, ensuring you're ready to start defining and managing your infrastructure as code.
"terraform" installation done just by dropping and playing the terraform binary or executable
Step 1: Downloading Terraform
Terraform is distributed as a standalone binary, making installation straightforward. Follow these steps to download Terraform:
Visit the official Terraform website: Terraform Downloads.
Identify the appropriate version for your operating system (Windows, macOS, or Linux).
Download the binary and save it to a directory on your machine.
Step 2: Installing Terraform
Windows:
Extract the downloaded zip file.
Move the
terraform.exe
binary to a directory included in your system's PATH.Open a command prompt and verify the installation by typing:
terraform -version
macOS:
Extract the downloaded archive.
Move the
terraform
binary to a directory in your PATH (e.g.,/usr/local/bin/
).Open a terminal and verify the installation.
terraform -version
AWS Linux:
Extract the downloaded archive.
Move the
terraform
binary to a directory in your PATH (e.g.,/usr/bin/terraform
).Open a terminal and verify the installation.
sudo yum install -y yum-utils shadow-utils
sudo yum-config-manager --add-repo https://rpm.releases.hashicorp.com/AmazonLinux/hashicorp.repo
sudo yum -y install terraform
terraform -version
If the installation was successful, you should see Terraform's version information, indicating that it's ready for use.
Step 3: Configuring Terraform
Before you start using Terraform, it's essential to configure it with your preferred settings and credentials. Follow these steps to configure Terraform:
Create a working directory.
Organize your Terraform projects by creating a dedicated directory for each. Navigate to your desired workspace.
mkdir my_terraform_project cd my_terraform_project
Initialize Terraform:
Run the following command to initialize Terraform in your project directory:
terraform init
This command downloads the necessary provider plugins and sets up your Terraform environment.
Configure provider credentials:
If you're working with a cloud provider (e.g., AWS, Azure), you'll need to configure your provider credentials. Use the command "
aws configure
" for configuring AWS credentials:aws_access_key = "your_access_key" aws_secret_key = "your_secret_key"
Make sure to replace
"your_access_key"
and"your_secret_key"
with your actual credentials.(Optional) Configure additional settings:
Explore advanced configurations in the
terraform
block in yourmain.tf
file. For example, set a preferred backend for storing Terraform state remotely.main.tf terraform { backend "s3" { bucket = "my-terraform-state-bucket" key = "terraform.tfstate" region = "us-west-2" } }
Modify these settings according to your project requirements.
Running Multiple versions of terraform on same machine
By default, we run a single Terraform version on our machine. But we can make use of multiple versions of Terraform on the same machine. By copying various terraform versions inside, /usr/bin/terraform*
it will look like this:
/usr/bin/terraform_122 #rename terraform 1.2.2 binary
/usr/bin/terraform_157 #rename terraform 1.5.7 binary
Configure default version by creating symbolic link as:
/usr/bin/terraform -> /usr/bin/terraform_122
If I want to use version 1.5.7 for my work, I can explicitly use the corresponding version as follows:
terraform_157 --version
terraform_157 init
terraform_157 plan
If I want to use version 1.2.2 for my work, I can explicitly use the corresponding version as follows:
terraform_122 --version
As we can see, Terraform is symlinked to/usr/bin/terraform_122
, the default version is set to 1.2.2 on your system, and it can be used as usual, i.e.
terraform --version
Conclusion:
Congratulations! You've successfully installed and configured Terraform for your environment. With Terraform initialized and your credentials set up, you're ready to start defining infrastructure as code. In the next blog post, we'll explore the basics of creating your first Terraform configuration and provisioning resources. Stay tuned for an exciting journey into the world of infrastructure as code with Terraform!