Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How organize terraform modules for common load balancer

I have AWS ALB that using for multiple EC2 instances. In Terraform i have alb module which already created load balancer and listeners, target groups for that EC2 instances.

I want attach ec2 instance to target group . I did this in EC2 instance module which got ALB instace id from load balancer module outputs.

When i perform terraform apply command in ec2 instance module terraform wants to crete new ALB but its already created and using. Terraform state in ec2 module don't know about ALB but wants to perform code from this module to get outputs

How can i organize modules using common ALB for multiple EC2 instances without recreating ALB for every new EC2 instance?

like image 251
user13871033 Avatar asked Jul 05 '20 14:07

user13871033


People also ask

How do I use multiple modules in Terraform?

There is one module to deploy a frontend-app, another to deploy a backend-app, another for the MySQL database, and so on. To deploy such an environment, you'd have to manually run terraform apply in each of the subfolder, wait for it to complete, and then run terraform apply in the next subfolder.

What steps should be followed for making an object of one module to be available for the other module at a high level?

Following are the steps which should be followed for making an object of one module to be available for the other module at a high level: First, an output variable to be defined in a resource configuration. Till you do not declare resource configuration details, the scope of local and to a module.


1 Answers

The way in which you should do this is the following:

  • Create a module for ALB, in your output.tf output the target group arn that you would like your Ec2 instance(s) to use
  • Create a module for EC2, include a aws_lb_target_group_attachment resource. Add a variable for the target group
  • In your main.tf create the load balancer via the ALB module first, then call the EC2 module for each instance you want to use, for the target group argument reference the ALB module name and its output variable for the target group.

An example main.tf including only the relevant parts

module "my_alb_module" {
   .....
}

module "my_ec2_module" {
    target_group_arn = module.my_alb_module.target_group
}

As a point of best practice if you have components like a load balancer and ec2, try to keep them in separate modules if you want to support reusability between resources.

Whilst not a direct example checkout the code from this GitHub repository, it illustrates how values can be exported between modules.

like image 177
Chris Williams Avatar answered Nov 13 '22 13:11

Chris Williams