Skip to content

Latest commit

 

History

History
96 lines (57 loc) · 3.15 KB

README.md

File metadata and controls

96 lines (57 loc) · 3.15 KB

Terraform Ansible LAMP with RDS

--- ---

We are trying to create a High Available LAMP architecture here using AWS cloud. Here we will be using RDS as our MySql DB and Ubuntu 20.4 as our web servers. Since we are using RDS, patching or any other maintainence activity is taken care by AWS. Hence we don't need NAT gateway or instance. Anyway they cost a lot too. But RDS with Multi AZ also has a high price, but you get high availability of the site.

Here is the reference architecture that We are going to Spin up using Terraform(Infra Provisioning) And Ansible(Configuration Management).

AWS

Pre-requisites to Run the script

  1. AWS Account

  2. Access Key & Secret Access Key for an administrator command line user

  3. Terraform (minimum version 13.0) as mentioned in provider.tf

    required_version = "~> 0.13"

  4. Create a key pair in the region you want to deploy (Default here is ap-south-1, but you can change in terraform.tfvars)

Steps to run the Scripts

  1. Clone the repository

git clone https://github.com/Dash2701/terraform-ansible-lamp.git

  1. Go to the repository

cd terraform-ansible-lamp

  1. Open terraform.tfvars and replace your values.
#The Region you want to deploy the infra
aws_region         = "ap-south-1"

# Replace the VPC cidr from your account. Range of CIDR max(22)
vpc_cidr           = "172.168.96.0/22"

# Key pair name create in same region
key_name           = "lamp"

# personal laptop public ip for debugging and SSH purpose
personal_laptop_ip = "182.70.99.206"
  1. Initialiaze the terraform so that all related plugins gets download

terraform init

  1. Run Apply and the approve with yes command

terraform apply

or directly auto approve it

terraform apply --auto-approve

  1. After completion the ALB URL and DB DNS will be there in the outputs section similar to this
alburl = "lamp-alb-******.ap-south-1.elb.amazonaws.com"
dburl = "lampdb.******.ap-south-1.rds.amazonaws.com"
  1. On hittng the ALB you should be able to see index.html for apache web servers.

Ansible Part

We are using the EC2 user data to install Ansible and do the installation of the LAMP required packages. The user data that we are passing to the instance is the filename: installAnsibleUbuntu.sh

You can clone the Ansible Script here:

git clone https://github.com/Dash2701/ansible-lamp.git

This is just a sample and only the apache sever is running here. And when you access the instances you can do the following command to check access to MySql Database in RDS using the terraform output dburl.

nc lampdb.******.ap-south-1.rds.amazonaws.com 3306 -v

And hence we can start building the LAMP application as required.

Anything better we can do

Yes absolutely.. We can prepare modules in Terraform for better code management along with separate state files for separate components.. separate for networks, applications, database, iam etc.. And for security of the Terrform State we can use remote state backend along with lock functionality so you can work on it from anywhere or many members can work on it.