Skip to content

Contact sales

By filling out this form and clicking submit, you acknowledge our privacy policy.
  • Labs icon Lab
  • A Cloud Guru
Labs

Building Flexible Network Templates in GCP with Terraform

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.

Labs

Path Info

Level
Clock icon Advanced
Duration
Clock icon 1h 0m
Published
Clock icon Apr 08, 2022

Contact sales

By filling out this form and clicking submit, you acknowledge our privacy policy.

Table of Contents

  1. Challenge

    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.
  2. Challenge

    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.

The Cloud Content team comprises subject matter experts hyper focused on services offered by the leading cloud vendors (AWS, GCP, and Azure), as well as cloud-related technologies such as Linux and DevOps. The team is thrilled to share their knowledge to help you build modern tech solutions from the ground up, secure and optimize your environments, and so much more!

What's a lab?

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.

Provided environment for hands-on practice

We will provide the credentials and environment necessary for you to practice right within your browser.

Guided walkthrough

Follow along with the author’s guided walkthrough and build something new in your provided environment!

Did you know?

On average, you retain 75% more of your learning if you get time for practice.

Start learning by doing today

View Plans