Provision three tier architecture on AWS using Terraform
- AWS CLI installed
- AWS configure on our local machine. To verify this second close, we must type the following command:
aws configure
To realize this project, we are going to create in aws, resources, to contain the state of terraform. this allows several developers to work on the same repository so that each one can make their own changes:
4- Fill in the form for the creation of an S3 Bucket as shown in the following image:
Note : In my case, I used utrains-bucket-backend-three-tier-app as my Bucket name. This will be used in our terraform code to configure the backend.
- In the search bar of the aws console, type DynamoDB, then click on DynamoDb to select
- In the page that appears, click on create table
- Fill the form by putting the name of the table (utrains-dynamodb-backend-three-tier-app) in my case, the partition key (utrainsKey). to finish, scroll down and click on create table. This no and this key will allow us to configure our backend in the Terraform code.
- the result of the table is as follows:
Now, let's open the backend.tf file, then add the information (name of our S3 bucket creer) and the name of our dynamoDB table.
for my case, I will have the following content:
terraform {
backend "s3" {
bucket = "utrains-bucket-backend-three-tier-app"
encrypt = true
key = "terraform.tfstate"
region = "us-west-2"
dynamodb_table = "utrains-dynamodb-backend-three-tier-app"
}
}
- Now everything is configured, we can perform the terraform commands below to create our resources in AWS, then store the state of these resources in our S3 Bucket.
terraform init
terraform plan
terraform apply -auto-approve
- After the creation of all the resources, we can open the aws console, go to our bucket, then consult the state file of our created infrastructure. click on Open to see this file,is a JSON file
- Open the subnets, to see the created subnets:
- open ec2 console then see the 2 instances that is created.
- go to Load balancer
- copy the dns name, then paste in the browser. You can see that the
- in the browser, the apache test page can be display
-
To see the php info page, you must add to the url of the DNS Name /phpinfo.php. In my case, I will have : http://dev-alb-413514277.us-east-1.elb.amazonaws.com/phpinfo.php
-
Page that we have :
- If we refresh the browser, we can see that the name of the server changes: this is the load balancer
-
To login in to php myadmin, you must add to the url of the DNS Name /phpMyAdmin. In my case, I will have : http://dev-alb-413514277.us-east-1.elb.amazonaws.com/phpMyAdmin, The login page of php MyAdmin display.
-
To get the login information, go to the terminal where the terrraform state file is located and enter the commands below:
- username : open the terraform.tfvars file, in line 65, you can see the rds_username = "dev_user"
- password : The password is generated from terraform. To see the value of this password, enter the following command to display the output of the password.
terraform output db_instance_password
-
To log into Php MyAdmin, we just need to use this password and the user name :
- Once logged in, we can see the php MyAdmin page, where we can create our database tables
- When we have finished testing, we can use the following command to destroy all the resources created in AWS.
terraform destroy -auto-approve
- Manually delete the S3 Bucket and DynamoDB in the AWS console