diff --git a/main.tf b/main.tf index 9b32ce06b..769155341 100644 --- a/main.tf +++ b/main.tf @@ -3,7 +3,7 @@ data "aws_ami" "app_ami" { filter { name = "name" - values = ["bitnami-tomcat-*-x86_64-hvm-ebs-nami"] + values = [var.ami_filter.name] } filter { @@ -11,14 +11,84 @@ data "aws_ami" "app_ami" { values = ["hvm"] } - owners = ["979382823631"] # Bitnami + owners = [var.ami_filter.owner] # Bitnami } -resource "aws_instance" "web" { - ami = data.aws_ami.app_ami.id - instance_type = "t3.nano" + +module "blog_vpc" { + source = "terraform-aws-modules/vpc/aws" + + name = var.environment.name + cidr = "${var.environment.network_prefix}.0.0/16" + + azs = ["us-west-2a","us-west-2b","us-west-2c"] + public_subnets = ["${var.environment.network_prefix}.101.0/24", "${var.environment.network_prefix}.102.0/24", "${var.environment.network_prefix}.103.0/24"] + + + tags = { + Terraform = "true" + Environment = var.environment.name + } +} + + +module "blog_autoscaling" { + source = "terraform-aws-modules/autoscaling/aws" + version = "6.5.2" + + name = "blog" + + min_size = var.asg_min + max_size = var.asg_max + vpc_zone_identifier = module.blog_vpc.public_subnets + target_group_arns = module.blog_alb.target_group_arns + security_groups = [module.blog_sg.security_group_id] + instance_type = var.instance_type + image_id = data.aws_ami.app_ami.id +} + +module "blog_alb" { + source = "terraform-aws-modules/alb/aws" + version = "~> 6.0" + + name = "blog-alb" + + load_balancer_type = "application" + + vpc_id = module.blog_vpc.vpc_id + subnets = module.blog_vpc.public_subnets + security_groups = [module.blog_sg.security_group_id] + + target_groups = [ + { + name_prefix = "blog-" + backend_protocol = "HTTP" + backend_port = 80 + target_type = "instance" + } + ] + + http_tcp_listeners = [ + { + port = 80 + protocol = "HTTP" + target_group_index = 0 + } + ] tags = { - Name = "HelloWorld" + Environment = "dev" } } + +module "blog_sg" { + source = "terraform-aws-modules/security-group/aws" + version = "4.13.0" + + vpc_id = module.blog_vpc.vpc_id + name = "blog" + ingress_rules = ["https-443-tcp","http-80-tcp"] + ingress_cidr_blocks = ["0.0.0.0/0"] + egress_rules = ["all-all"] + egress_cidr_blocks = ["0.0.0.0/0"] +} diff --git a/outputs.tf b/outputs.tf index b35171bef..8b1378917 100644 --- a/outputs.tf +++ b/outputs.tf @@ -1,7 +1 @@ -#output "instance_ami" { -# value = aws_instance.web.ami -#} -#output "instance_arn" { -# value = aws_instance.web.arn -#} diff --git a/variables.tf b/variables.tf index c750667e0..1fed6f256 100644 --- a/variables.tf +++ b/variables.tf @@ -1,4 +1,41 @@ -#variable "instance_type" { -# description = "Type of EC2 instance to provision" -# default = "t3.nano" -#} +variable "instance_type" { + description = "Type of EC2 instance to provision" + default = "t3.nano" +} + +variable "ami_filter" { + description = "Name filter and owner for AMI" + + type = object ({ + name = string + owner = string + }) + + default = { + name = "bitnami-tomcat-*-x86_64-hvm-ebs-nami" + owner = "979382823631" # Bitnami + } +} + +variable "environment" { + description = "Deployment environment" + + type = object ({ + name = string + network_prefix = string + }) + default = { + name = "dev" + network_prefix = "10.0" + } +} + +variable "asg_min" { + description = "Minimum instance count for the ASG" + default = 1 +} + +variable "asg_max" { + description = "Maximum instance count for the ASG" + default = 2 +}