Skip to content

Instantly share code, notes, and snippets.

@ravsau
Last active June 15, 2021 06:24
Show Gist options
  • Save ravsau/481659c586e861c538300a26ef6df347 to your computer and use it in GitHub Desktop.
Save ravsau/481659c586e861c538300a26ef6df347 to your computer and use it in GitHub Desktop.
Terraform lab

In this mini lab/lesson we are going to provision an EC2 using Hashicorps's terraform.

Reference: https://www.terraform.io/docs/providers/aws/index.html

Find the code and steps for this Lab here: https://github.com/ravsau/aws-labs/tree/master/terraform-aws

What is Terraform?

Terraform is a tool made by Hashicorp for building, changing, and versioning infrastructure safely and efficiently. Terraform can manage existing and popular service providers ( aws, azure, Google cloud) as well as custom in-house solutions.

You can compare Terraform to Cloudformation . They are simililar but at the same time have differences.

Steps to provision

  1. Download the terraform binary file https://www.terraform.io/downloads.html

If MAC users have homebrew installed on their machine: Just do: brew install terraform Go to step 5

  1. Extract the zip file
  2. You will see the terraform binary executable file
  3. make sure that the terraform binary is available on the PATH.

For Mac/Linux. On the shell/terminal, go to the folder where terraform binary is extracted

echo $"export PATH=\$PATH:$(pwd)" >> ~/.bash_profile
source ~/.bash_profile

For Windows users : follow this to add Terraform to PATH https://stackoverflow.com/questions/1618280/where-can-i-set-path-to-make-exe-on-windows

  1. make a new directory(can be named anything) and go inside the directory
mkdir terraform-july && cd terraform-july
  1. Paste this following code to a file called ec2.tf( can be anything.tf)

minimal viable configuration

provider "aws" {
  access_key = "ACCESS_KEY_HERE"
  secret_key = "SECRET_KEY_HERE"
  region     = "us-east-1"
}

resource "aws_instance" "example" {
  ami           = "ami-2757f631"
  instance_type = "t2.micro"
}

Note:

Replace the access_key and secret_access with your AWS IAM user credentials with enough permissions attached. You can go to IAM console on AWS to do this. First, go to the IAM management console iam

Then Click on the user's name and navigate to the security credentials tab. Click create access keys iam

Either download the csv file or, click show keys. Now you have both the access_key and secret_key required for the terraform code above. iam

If you've setup the AWS CLI and have credentials stored , you may skip the credential portion. This is what Hashicorp says "If you simply leave out AWS credentials, Terraform will automatically search for saved API credentials (for example, in ~/.aws/credentials) or IAM instance profile credentials. This option is much cleaner for situations where tf files are checked into source control"

  1. initialize the working directory for terraform
terraform init

"The terraform init command is used to initialize a working directory containing Terraform configuration files. This is the first command that should be run after writing a new Terraform configuration or cloning an existing one from version control. It is safe to run this command multiple times."

  1. Provision the ec2 with this command
terraform apply
  1. Login to the AWS management console and navigate to the EC2 management console. Check if an instance got provisioned

  2. From your terminal/command prompt/ shell , destory the resources

terraform destroy

That's it! you installed Terraform and used it to proision an EC2 instance.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment