Building Flexible Network Templates in GCP with Terraform

1 hour
  • 2 Learning Objectives

About this Hands-on Lab

You are a DevOps engineer at an organization that is moving their configuration management to Infrastructure as Code (IaC) using Terraform. The networking team wants to move to managing their GCP VPCs and subnets with Terraform, but is concerned that maintaining separate code bases for development and production networks would lead to the environments not having the same configurations. You will create a single Terraform module and build both production and development VPCs using that module. This way, the environments will remain mirrored, and managing changes will be transparent and auditable.

Learning Objectives

Successfully complete this lab by achieving the following learning objectives:

Create a ‘networking’ Module and Use It to Create a Small Development VPC
  • Create a terraform directory to work in.
  • Create a modules/networking directory, and create a main.tf inside of it.
  • Define variables for environment, cidr_range, regions and subnet_size.
  • Create a locals block and use the split(), element(), length(), and tonumber() Terraform functions to calculate the newbits value for the cidrsubnet() function argument.
  • Create a google_compute_network resource.
  • Create a google_compute_subnetwork resource. Use the count argument to create a subnet in each region in the regions variable. Use the cidrsubnet() function to calculate the ip_cidr_range based on the cidr_range variable.
  • In the terraform directory, create a dev folder containing a main.tf file.
  • Create a terraform block and a module referencing the modules/networking code. Set the environment to dev, the cidr_range to 10.10.0.0/24, regions to ["us-central1", "us-east1"], and subnet_size to 28.
  • Execute terraform init.
  • Execute terraform apply.
Using the Same Module, Create a Production VPC with a Larger CIDR Block and More Subnets
  • In the terraform directory, create a prod folder containing a main.tf file.
  • Create a terraform block and a module referencing the modules/networking code. Set the environment to prod, the cidr_range to 10.0.0.0/8, regions to ["us-central1", "us-east1", "us-east4", "us-west1"], and subnet_size to 24.
  • Execute terraform init.
  • Execute terraform apply.

Additional Resources

Lab Resources

  • Terraform Modules: Modules provide a way to wrap a common set of resources while exposing specific arguments that can be customized.
  • Terraform Functions: Terraform contains a number of built in functions to manipulate values.

What are Hands-on Labs

Hands-on Labs are real environments created by industry experts to help you learn. These environments help you gain knowledge and experience, practice without compromising your system, test without risk, destroy without fear, and let you learn from your mistakes. Hands-on Labs: practice your skills before delivering in the real world.

Sign In
Welcome Back!

Psst…this one if you’ve been moved to ACG!

Get Started
Who’s going to be learning?