top of page
nlsamkariashiva

Formating terraform configuration

Updated: Dec 5, 2023

Formatting Terrafo

rm configuration is important for readability, maintainability, and collaboration with other team members. Terraform supports HashiCorp Configuration Language (HCL) for defining infrastructure as code. Here are some best practices for formatting Terraform configuration files:


1. Use Consistent Indentation:

- Use two spaces or four spaces for indentation (whichever is your team's preference), and be consistent throughout the configuration file.


2. Organize Resources:

- Group related resources together, such as all AWS instances, security groups, and subnets for a particular application.


3. Use Descriptive Names:

- Use descriptive names for resources, variables, and outputs to make the code more self-explanatory.


4. Use Comments:

- Add comments to explain the purpose and important details of resources or variables.

- Use `#` for single-line comments and `/* ... */` for multi-line comments.





# This is a single-line comment

/*
  This is a multi-line comment
  that explains a complex resource configuration.
*/



5. Use Consistent Capitalization:

- Follow consistent capitalization conventions for resource names and variable names. It's common to use lowercase with underscores for variable names and lowercase camelCase or hyphen-separated names for resource names.


6. Align Attributes:

- Align resource attributes for better readability. For example:




resource "aws_instance" "example" {
  ami           = "ami-12345678"
  instance_type = "t2.micro"
  subnet_id     = aws_subnet.example.id
}


7. Use Terraform Variables:

- Define variables to make your configuration more dynamic and reusable. Use variable declarations at the top of your configuration file or in separate variable files.



variable "ami_id" {
  description = "The ID of the AMI to use."
  type        = string
  default     = "ami-12345678"
}


8. Use Terraform Modules:

- Break down your infrastructure into reusable modules to avoid code duplication and improve maintainability.


9. Use Terraform Blocks:

- Use blocks for repeated resource configurations instead of duplicating the same code.




resource "aws_security_group" "example" {
  name        = "example"
  description = "Example security group"
  
  # Ingress block for port 80
  ingress {
    from_port   = 80
    to_port     = 80
    protocol    = "tcp"
    cidr_blocks = ["0.0.0.0/0"]
  }

  # Ingress block for port 443
  ingress {
    from_port   = 443
    to_port     = 443
    protocol    = "tcp"
    cidr_blocks = ["0.0.0.0/0"]
  }
}


10. Use Terraform Output:

- Define outputs to expose important information that might be useful to other parts of your infrastructure or for human consumption.




output "public_ip" {
  description = "The public IP address of the instance."
  value       = aws_instance.example.public_ip
}


11. Use Terraform fmt:

- Use the `terraform fmt` command to automatically format your Terraform configuration files according to the conventions defined in the Terraform style guide.


12. Follow Terraform Best Practices:

- Familiarize yourself with Terraform best practices and guidelines, which can help you write clean and maintainable code.


By following these formatting guidelines and best practices, you can create Terraform configurations that are easier to read, understand, and maintain, ultimately making your infrastructure as code more efficient and less error-prone.

18 views0 comments

Comentarios


bottom of page