AWS Infrastructure Automated with Terrafrom

Complete Automated infrastructure build-up On AWS Cloud — EC2, S3 , Cloudfront using Terraform

Abhayjit kumar
5 min readJun 16, 2020

--

Terraform

Terraform is a tool for building, changing, and versioning infrastructure safely and efficiently. Terraform can manage existing and popular service providers as well as custom in-house solutions.

Configuration files describe to Terraform the components needed to run a single application or your entire datacenter. Terraform generates an execution plan describing what it will do to reach the desired state, and then executes it to build the described infrastructure. As the configuration changes, Terraform is able to determine what changed and create incremental execution plans which can be applied.

The infrastructure Terraform can manage includes low-level components such as compute instances, storage, and networking, as well as high-level components such as DNS entries, SaaS features, etc.

Task_1 : Launch An Application/Website using Terraform

1. Create the key and security group which allow the port 80.

2. Launch EC2 instance.

3. In this EC2 instance use the key and security group which we have created in step 1.

4. Launch one Volume (EBS) and mount that volume into /var/www/html

5. Developer have uploded the code into github repo also the repo has some images.

6. Copy the github repo code into /var/www/html

7. Create S3 bucket, and copy/deploy the files from github repo into the s3 bucket and change the permission to public readable.

8 Create a Cloudfront using s3 bucket(which contains files) and use the Cloudfront URL to update in code in /var/www/html

9. Launch your webpage

Basic Terraform commands used

  1. terraform init
  2. terraform apply -auto-approve
  3. terraform destroy -auto-approve

Steps Performed

Step 1 : Create a directory and within that create a sub-directory , here, create a .tf extension file using local editor . I have used notepad.

Step 2: Instructing the terraform that aws is our provider and choosing our region and default login on your local machine for aws.

provider "aws" {
region = "ap-south-1"
profile = "default"
}

Step 3: Key Creation

resource "tls_private_key" "webkey" {
algorithm = "RSA"
rsa_bits = 2048
}


resource "local_file" "private_key" {
content = tls_private_key.webkey.private_key_pem
filename = "mywebkey.pem"
file_permission = 0400
}


resource "aws_key_pair" "key" {
key_name = "websitekey"
public_key = tls_private_key.webkey.public_key_openssh
}

Step 4 : Default Vpc

resource "aws_default_vpc" "default" {
tags = {
Name = "Default VPC"
}

Step 5 : Create Security Group

resource "aws_security_group" "security" {
name = "websecurity"
description = "Allows ssh and http connection"
vpc_id = aws_default_vpc.default.id


ingress {
description = "SSH"
from_port = 22
to_port = 22
protocol = "tcp"
cidr_blocks = ["0.0.0.0/0"]
}




ingress {
description = "HTTP"
from_port = 80
to_port = 80
protocol = "tcp"
cidr_blocks = ["0.0.0.0/0"]
}


egress {
from_port = 0
to_port = 0
protocol = "-1"
cidr_blocks = ["0.0.0.0/0"]
}


tags = {
Name = "websecuritygroup"
}
}

Step 6: Launch EC2 instance and install php httpd and git for further application use.

resource "aws_instance" "web" {
ami = "ami-0447a12f28fddb066"
instance_type = "t2.micro"
key_name= aws_key_pair.key.key_name
security_groups = "websecurity"


connection {
type = "ssh"
user = "ec2-user"
private_key = tls_private_key.webkey.private_key_pem
host = aws_instance.web.public_ip
}


provisioner "remote-exec" {
inline = [
"sudo yum install httpd php git -y",
"sudo systemctl restart httpd",
"sudo systemctl enable httpd",
]
}


tags = {
Name = "WebOS"
}
}

Step 7 : Create a EBS(Elastic Block Storage) volume.

resource "aws_ebs_volume" "ebs" {
availability_zone = aws_instance.web.availability_zone
size = 1


tags = {
Name = "EBS"
}
}

Step 8: Attach EBS volume to our EC2 instance .

resource "aws_volume_attachment" "ebs_att" {
device_name = "/dev/sdh"
volume_id = "${aws_ebs_volume.ebs.id}"
instance_id = "${aws_instance.web.id}"
force_detach = true
}

Step 9 :Create partition , format and mount on var/www/html and clone your github program also.

resource "null_resource" "nullremote3"  {


depends_on = [
aws_volume_attachment.ebs_att,
]




connection {
type = "ssh"
user = "ec2-user"
private_key = tls_private_key.webkey.private_key_pem
host = aws_instance.web.public_ip
}


provisioner "remote-exec" {
inline = [
"sudo mkfs.ext4 /dev/xvdh",
"sudo mount /dev/xvdh /var/www/html",
"sudo rm -rf /var/www/html/*",
"sudo git clone https://github.com/Abhayjit404/aws_terrafor.git/var/www/html/"
]
}
}

Step 9 : Create a S3 bucket. Here, we copy/deploy images from github on our local machine folder in order to upload it on the bucket.

resource "aws_s3_bucket" "s3-bucket" {
bucket = "web-bucket-cook" //should be unique
acl = "public-read"
provisioner "local-exec" {
command = "git clone https://github.com/Abhayjit404/aws_terrafor.git multi-cloud"
}

tags = {
Name = "My-S3-bucket"
Environment = "Production"
}
versioning {
enabled= true
}

Step 10 : Upload images in our S3 bucket.

resource "aws_s3_bucket_object" "image-upload1" {
bucket = aws_s3_bucket.s3-bucket.bucket
key = "hamburger.jpg"
source = "multi-cloud/hamburger.jpg"
acl = "public-read"
}


resource "aws_s3_bucket_object" "image-upload2" {
bucket = aws_s3_bucket.s3-bucket.bucket
key = "tablesetting.jpg"
source = "multi-cloud/tablesetting.jpg"
acl = "public-read"
}


resource "aws_s3_bucket_object" "image-upload3" {
bucket = aws_s3_bucket.s3-bucket.bucket
key = "tablesetting2.jpg"
source = "multi-cloud/tablesetting2.jpg"
acl = "public-read"
}

Step 11:Create a Cloudfront to associate with the S3 bucket.

Amazon CloudFront is a fast content delivery network (CDN) service that securely delivers data, videos, applications, and APIs to customers globally with low latency, high transfer speeds, all within a developer-friendly environment.

locals {
s3_origin_id = "myS3Origin"
}
resource "aws_cloudfront_distribution" "s3_distribution" {
origin {
domain_name = "${aws_s3_bucket.s3-bucket.bucket_regional_domain_name}"
origin_id = "${local.s3_origin_id}"
custom_origin_config {
http_port = 80
https_port = 80
origin_protocol_policy = "match-viewer"
origin_ssl_protocols = ["TLSv1", "TLSv1.1", "TLSv1.2"]
}
}

enabled = true
default_cache_behavior {
allowed_methods = ["DELETE", "GET", "HEAD", "OPTIONS", "PATCH", "POST", "PUT"]
cached_methods = ["GET", "HEAD"]
target_origin_id = "${local.s3_origin_id}"
forwarded_values {
query_string = false

cookies {
forward = "none"
}
}
viewer_protocol_policy = "allow-all"
min_ttl = 0
default_ttl = 3600
max_ttl = 86400
}
restrictions {
geo_restriction {
restriction_type = "none"
}
}
viewer_certificate {
cloudfront_default_certificate = true
}
}

Step 12 : Okay we are done with our setup here. It is time to launch our Webpage.

resource "null_resource" "nulllocal1"  {
depends_on = [
null_resource.nullremote3,aws_s3_bucket_object.image-upload1,aws_s3_bucket_object.image-upload2,aws_s3_bucket_object.image-upload3,
]
provisioner "local-exec" {
command = "start chrome ${aws_instance.web.public_ip}"
}
}

A pop Up will appear of your chrome window.

--

--