Book Image

Terraform Cookbook - Second Edition

By : Mikael Krief
4.5 (2)
Book Image

Terraform Cookbook - Second Edition

4.5 (2)
By: Mikael Krief

Overview of this book

Imagine effortlessly provisioning complex cloud infrastructure across various cloud platforms, all while ensuring robustness, reusability, and security. Introducing the Terraform Cookbook, Second Edition - your go-to guide for mastering Infrastructure as Code (IaC) effortlessly. This new edition is packed with real-world examples for provisioning robust Cloud infrastructure mainly across Azure but also with a dedicated chapter for AWS and GCP. You will delve into manual and automated testing with Terraform configurations, creating and managing a balanced, efficient, reusable infrastructure with Terraform modules. You will learn how to automate the deployment of Terraform configurations through continuous integration and continuous delivery (CI/CD), unleashing Terraform's full potential. New chapters have been added that describe the use of Terraform for Docker and Kubernetes, and explain how to test Terraform configurations using different tools to check code and security compliance. The book devotes an entire chapter to achieving proficiency in Terraform Cloud, covering troubleshooting strategies for common issues and offering resolutions to frequently encountered errors. Get the insider knowledge to boost productivity with Terraform - the indispensable guide for anyone adopting Infrastructure as Code solutions.
Table of Contents (20 chapters)
16
Other Books You May Enjoy
17
Index

Generating multiple blocks with dynamic expressions

Terraform resources are defined by the following elements:

Properties that are in the form property name = value, which we have seen several times in this book

Blocks that represent a grouping of properties, such as the site_config block inside the azurerm_linux_web_app resource.

Depending on the Terraform resource, a block can be present once or even multiple times in the same resource, such as the security_rule block inside the azurerm_network_security_group resource (see the documentation, for example, at  https://registry.terraform.io/providers/hashicorp/azurerm/latest/docs/resources/network_security_group).

Until Terraform version 0.12, it was not possible to make these blocks present several times in the same resource dynamically using, for example, a variable of list type.

One of the great feature Terraform is the dynamic expression...