Introduction
Hey there Everyone! đż Welcome back to our Terraform on Azure series. If youâve been following along, youâre in for a treat today. Weâre about to embark on an exciting journey â creating your very first full-fledged Terraform project on Azure!
Where Weâve Been
Letâs quickly recap our adventure so far:
- In our first article, we explored the fundamentals of Terraform and why itâs such a game-changer for managing Azure infrastructure.
- In the second article, we got our hands dirty setting up our local Terraform environment, complete with Azure CLI, Terraform installation, and a shiny VS Code setup.
If you havenât read these articles yet, no worries! You might want to give them a quick squiz to make sure youâre all set up and ready to go.
What Weâre Building Today
Today, weâre taking off the training wheels and building a real Azure infrastructure using Terraform. Weâre not just talking about a lone resource group anymore â weâre going full steam ahead! đ
Hereâs a sneak peek of what weâll be creating:
- A Resource Group to keep everything tidy
- A Virtual Network to provide connectivity
- A Subnet to organize our network
- A Network Security Group to keep things locked down
- And the pièce de rĂŠsistance â a Virtual Machine to run our workloads
By the end of this guide, youâll have a fully functional Azure environment, all created and managed with Terraform. How choice is that?
What Youâll Learn
This hands-on project will teach you:
- How to plan your Azure infrastructure before writing any code
- The art of defining multiple, interconnected Azure resources in Terraform
- How to make your configuration flexible (weâll dip our toes into variables, but donât worry, we wonât go too deep just yet)
- The full Terraform workflow â from initialization to destruction
- How to verify your Azure resources and make changes to your infrastructure
Why This Matters
Creating a multi-resource project is a big step up from managing single resources. Itâs like going from building with blocks to constructing a full-on Lego city! This project will give you a taste of real-world infrastructure management, preparing you for more complex scenarios youâll encounter in your cloud journey.
So, are you ready to level up your Terraform skills and breathe life into your first Azure project? Grab your favorite beverage â, fire up your code editor, and letâs dive in!
Planning Our Azure Infrastructure
Before we start slinging Terraform code, letâs take a moment to plan out our Azure infrastructure. As the saying goes, âMeasure twice, cut onceâ â or in our case, âPlan thoroughly, Terraform once!â đâ¨
Our Infrastructure Blueprint
Weâre going to create a basic but realistic Azure environment. Hereâs what weâre aiming for:
-
Resource Group đŚ
- Think of this as a container for all our Azure resources. It helps us organize and manage related resources as a unit.
-
Virtual Network (VNet) đ
- This is our own private network in Azure. Itâs like setting up your own little internet within the Azure cloud.
-
Subnet đš
- A subnet is a range of IP addresses in your VNet. Weâll use this to organize and manage network traffic.
-
Network Security Group (NSG) đĄď¸
- This is our virtual firewall. It controls inbound and outbound traffic, keeping our resources safe.
-
Virtual Machine (VM) đť
- Finally, weâll create a VM where we can run our applications.
How These Components Interact
Letâs break down how these pieces fit together:
-
Everything lives inside our Resource Group. Itâs like a folder that keeps all our Azure resources neatly organized.
-
The Virtual Network provides the networking foundation. Itâs where all our network-related resources will reside.
-
Weâll create a Subnet within our VNet. This gives us a specific range of IP addresses to use for our resources.
-
The Network Security Group will be associated with our subnet. It acts as a gatekeeper, controlling what traffic is allowed in and out of our subnet.
-
Finally, our Virtual Machine will be placed in the subnet and protected by the NSG. It will have a network interface that connects it to the VNet, allowing it to communicate with other resources and the internet (if we allow it).
Hereâs a simple diagram of how it all fits together:
|
|
Why This Structure?
This setup gives us a solid, secure foundation for running applications in Azure:
- The Resource Group helps with organization and management.
- The VNet and Subnet provide network isolation.
- The NSG adds a layer of security.
- The VM gives us a place to run our applications.
Itâs a common pattern in Azure and a great starting point for more complex infrastructures.
Planning for Terraform
As we plan our Terraform configuration, weâll need to consider:
- The names and locations for our resources
- The address space for our VNet and Subnet
- The inbound and outbound rules for our NSG
- The size and OS for our VM
Donât worry if this seems like a lot â weâll tackle each piece step by step in our Terraform configuration.
Now that we have our blueprint, are you ready to start building? In the next section, weâll set up our Terraform configuration and start bringing this plan to life! Letâs get cracking! đď¸
Setting Up Our Terraform Configuration
Alright, team! Itâs time to roll up our sleeves and start setting up our Terraform configuration. Weâre going to create a new project directory and initialize our Terraform workspace. Letâs dive in! đââď¸
Creating the Project Directory
First things first, letâs create a new directory for our project:
- Open your terminal or command prompt.
- Navigate to where you want to create your project.
- Create a new directory and move into it:
|
|
Good on ya! Youâve just created a home for your Terraform project. đ
Creating Our Main Configuration File
Now, letâs create our main Terraform configuration file:
- In your project directory, create a new file named
main.tf
. - Open this file in your favorite text editor (remember that snazzy VS Code setup we did earlier?).
Configuring the Azure Provider
In our main.tf
file, weâll start by configuring the Azure provider. This tells Terraform that weâre working with Azure and sets up some basic parameters.
Add the following code to your main.tf
:
|
|
Letâs break this down:
- The
terraform
block specifies that weâre using the Azure Resource Manager (azurerm) provider. - The
provider
block configures the Azure provider. Weâre using a simple configuration here, but you can add more options as needed.
Initializing Our Terraform Working Directory
Now that we have our basic configuration set up, itâs time to initialize our Terraform working directory:
- In your terminal, make sure youâre in your project directory.
- Run the following command:
|
|
This command does a few important things:
- Downloads the Azure provider plugin
- Sets up the directory for use with Terraform
- Creates a
.terraform
directory to store the provider plugin and other necessary files
If everything goes well, you should see a message saying âTerraform has been successfully initialized!â
Congratulations! đ Youâve just set up and initialized your Terraform configuration for Azure. Weâre ready to start defining our resources.
In the next section, weâll start adding the Azure resources we planned earlier to our Terraform configuration. Weâll also introduce some basic ways to make our configuration more flexible, including specifying our deployment region. Ready to see your infrastructure start taking shape? Letâs keep the momentum going! đ
Defining Azure Resources in Terraform
Now that weâve got our Terraform configuration initialized, itâs time to breathe life into our Azure infrastructure. Weâre going to define each of the resources we planned earlier, right here in our main.tf
file. Exciting stuff!
Resource Blocks in Terraform
In Terraform, we define Azure resources using resource blocks. The basic structure looks like this:
|
|
type
is the type of Azure resource (likeazurerm_resource_group
)name
is a unique identifier for this resource in your Terraform config
Letâs get cracking and define our resources one by one!
1. Resource Group
First up, letâs create our resource group. Remember, this is like a container for all our other Azure resources. Add this to your main.tf
:
|
|
Here, weâre creating a resource group named âmyTFResourceGroupâ in the Australia East region. Choice location, mate! đŚ
2. Virtual Network (VNet)
Next, letâs set up our virtual network. This will be our private network in Azure. Add this after your resource group definition:
|
|
Notice how weâre referencing the resource group we just created? Thatâs the power of Terraform â resources can reference each other!
3. Subnet
Now, letâs carve out a subnet within our VNet:
|
|
This creates a subnet with a range of IP addresses for our resources to use.
4. Network Security Group (NSG)
Time to add some security! Letâs create a network security group:
|
|
This NSG allows inbound RDP traffic (port 3389). In a real-world scenario, youâd want to restrict the source address prefix for better security.
5. Network Interface Card (NIC)
Before we create our VM, we need to set up a network interface for it:
|
|
This NIC will allow our VM to communicate on the network.
6. Virtual Machine
Last but not least, letâs create our Windows virtual machine:
|
|
Note: In a real-world scenario, youâd want to use a more secure method for handling passwords, like using Azure Key Vault or environment variables. Weâre using a plain text password here for simplicity, but remember - never commit passwords to version control!
Wahoo! Weâve now defined all our planned Azure resources in Terraform. đ
In the next section, weâll look at ways to make our configuration more flexible and reusable. Weâre making great progress, team! Keep up the great work! đŞ
Making Our Configuration Flexible
Weâve got our resources defined, but letâs take it up a notch. Itâs time to make our configuration more flexible and reusable. Weâre going to dip our toes into the world of Terraform variables. Donât worry, we wonât go too deep â weâre just getting a taste today!
Why Use Variables?
Imagine you want to create similar infrastructure in different environments, or you need to change a value thatâs used in multiple places. Without variables, youâd have to manually update each instance. Thatâs not very efficient, is it? Variables help us avoid this hassle.
Introducing Variables
Letâs start by creating a new file called variables.tf
in the same directory as our main.tf
. This is where weâll define our variables.
Open variables.tf
and add the following:
|
|
These variables define default values for some of the parameters weâve been using in our configuration.
Using Variables in Our Configuration
Now, letâs update our main.tf
to use these variables. Weâll replace hard-coded values with references to our variables.
Update your resource group definition in main.tf
:
|
|
Do the same for the virtual network:
|
|
And for the subnet:
|
|
Finally, update the VM size in the virtual machine resource:
|
|
The Benefits of Using Variables
By using variables, weâve made our configuration more flexible:
- Easy Updates: If we need to change the resource group name or location, we only need to update it in one place.
- Reusability: We can now easily use this configuration for different environments by providing different variable values.
- Readability: Our main configuration is now cleaner and easier to understand.
A Sneak Peek at Variable Overrides
While weâre using default values here, Terraform allows you to override these values when you run your commands. For example:
|
|
This would use the new values instead of the defaults. Neat, eh?
Weâve just scratched the surface of variables here. Thereâs a lot more to learn, but donât worry â weâll dive deeper in a future article dedicated to Terraform variables.
Great job, team! đ Weâve added flexibility to our configuration. In the next section, weâll look at creating output values to easily retrieve important information about our infrastructure. Ready to keep rolling? Letâs go! đ
Creating Output Values
Weâre making great progress. Now, letâs talk about a crucial feature of Terraform: output values. These are especially important for retrieving information that isnât known until after Terraform has done its work.
Why Outputs Are Essential
Imagine this scenario: Youâve set up a Virtual Machine, but you donât know what IP address it will be assigned until itâs actually created. Thatâs where outputs come in handy! They allow us to capture and display information thatâs only available after Terraform has finished applying the configuration.
Outputs are super useful for:
- Retrieving values that are generated during the creation of resources (like IP addresses, generated names, etc.)
- Passing information to other parts of your infrastructure or to other systems
- Providing data for scripts or other tools that might use your Terraform configuration
Think of outputs as Terraformâs way of saying, âHereâs what Iâve created for you!â đ˘
Defining Output Values
Letâs create a new file called outputs.tf
in the same directory as our main.tf
and variables.tf
. Weâll define some useful outputs, including one for that dynamically assigned IP address we talked about.
Open outputs.tf
and add the following:
|
|
Letâs break this down:
- Weâre outputting the name of our resource group.
- Weâre outputting the name of our virtual machine.
- Most importantly, weâre outputting the private IP address of our VMâs network interface. This value isnât known until Azure assigns it during the creation of the VM!
Why That Last Output is So Important
The virtual_machine_private_ip_address
output is capturing a value that we couldnât have known beforehand. Azure dynamically assigns this IP address when it creates the network interface for our VM. By defining this as an output, weâre telling Terraform to fetch this value once itâs available and make it easily accessible to us.
This is incredibly useful in real-world scenarios. For example:
- You might need this IP address to configure other resources that need to communicate with this VM.
- You could use this in a script that automatically updates DNS records with the new VMâs IP.
- It could be used in subsequent Terraform runs or other automation tools that need to know how to reach this VM.
Viewing and Using Outputs
After you run terraform apply
, Terraform will display the outputs at the end of its run. You can also view the outputs at any time by running:
|
|
Or for a specific output:
|
|
In automation scenarios, you could capture these outputs and use them as inputs for other processes. For instance, a CI/CD pipeline might use the VMâs IP address to deploy an application to it after Terraform has finished creating the infrastructure.
By using outputs, especially for values that are only known after resource creation, weâre making our Terraform configuration more powerful and enabling smoother automation and integration with other systems. Itâs like leaving breadcrumbs for our future selves or other parts of our infrastructure to follow! đ
Reviewing Our Terraform Configuration
Weâve come a long way in building our Azure infrastructure with Terraform. Now, letâs take a step back and look at the big picture. Weâll review all the files weâve created and see how they work together to define our infrastructure.
Our Terraform File Structure
First, letâs recap the files weâve created:
main.tf
: Our primary configuration filevariables.tf
: Where we define our input variablesoutputs.tf
: Where we specify our output values
This structure helps keep our code organized and easy to maintain. Letâs dive into each file:
main.tf: The Heart of Our Configuration
Our main.tf
file is where the magic happens. Hereâs a quick rundown of what weâve defined:
|
|
This file defines all our Azure resources, from the resource group to the virtual machine. Notice how weâre using variables (var.something
) throughout the configuration. This makes our code more flexible and reusable.
variables.tf: Defining Our Input Variables
In variables.tf
, weâve defined variables that make our configuration flexible:
|
|
These variables allow us to easily change key aspects of our infrastructure without modifying the main configuration.
outputs.tf: Specifying Our Output Values
Finally, in outputs.tf
, weâve defined outputs to easily retrieve important information:
|
|
These outputs will provide us with key information after Terraform creates our resources, including that all-important dynamically assigned private IP address.
How It All Fits Together
- Terraform reads the configuration in
main.tf
. - It uses the values from
variables.tf
(or values we provide at runtime) to fill in the blanks. - It determines the required actions to create or modify the infrastructure.
- After applying the configuration, it presents the information weâve requested in
outputs.tf
.
This structure allows us to maintain a clean, organized, and flexible Terraform configuration. We can easily modify variables to create different environments, and we have easy access to important information about our infrastructure through outputs.
Awesome work, team! đ Weâve built a robust, flexible Terraform configuration for our Azure infrastructure. In the next section, weâll learn how to initialize our Terraform project and validate our configuration. Ready to bring our infrastructure to life? Letâs go! đ
Initializing and Validating Our Terraform Project
Now that weâve got our configuration files all sorted, itâs time to take our first steps towards bringing our infrastructure to life. Weâll start by initializing our Terraform project and then validate our configuration to make sure everything is in great shape.
Initializing Our Terraform Project
First things first, we need to initialize our Terraform working directory. This step downloads the necessary provider plugins and sets up the backend. Itâs like prepping our kitchen before we start cooking!
- Open your terminal or command prompt.
- Navigate to the directory containing your Terraform files.
- Run the following command:
|
|
You should see output similar to this:
|
|
What just happened? đ¤
- Terraform downloaded the Azure provider plugin.
- It set up the backend (where Terraform stores its state).
- It created a
.terraform
directory to store these components.
Think of this step as Terraform unpacking its toolbox and getting ready to work!
Validating Our Terraform Configuration
Now that weâre initialized, letâs make sure our configuration is valid. Terraform provides a handy command for this:
|
|
This command checks your configuration files for syntax errors and internal consistency. Itâs like a spell-check for your Terraform code!
If everything is correct, you should see:
|
|
Wahoo! đ Your configuration passed the check.
If there are any issues, Terraform will provide helpful error messages. For example:
|
|
This error would indicate that we forgot to give a name to our resource group resource. Terraformâs error messages are usually quite clear about whatâs wrong and where to find the issue.
What If There Are Errors?
Donât worry if you see errors â theyâre a normal part of the development process. Hereâs what to do:
- Read the error message carefully. It usually points to the exact file and line where the problem is.
- Check that file and line for typos or missing brackets.
- Make sure all your resource blocks have both a type and a name.
- Verify that all your variables are defined and used correctly.
- After making changes, run
terraform validate
again.
Remember, itâs much better to catch these errors now than when we try to apply our configuration!
Best Practices
- Run
terraform init
whenever you add new providers or modules to your configuration. - Use
terraform validate
frequently as you write your configuration. It can save you a lot of time by catching errors early. - If youâre using version control (which you should be!), run
terraform validate
before committing your changes. Itâs a great way to catch errors before they make it into your repository.
Great work, team! đ Weâve initialized our project and validated our configuration. Weâre now ready to take the next big step â planning our infrastructure deployment. Excited to see what Terraform is going to do? Letâs keep rolling! đ
Planning Our Infrastructure Deployment
Now that weâve initialized our project and validated our configuration, itâs time for one of the most exciting parts of working with Terraform: planning our infrastructure deployment. This is where we get to see a preview of what Terraform is going to do before it actually does it. Itâs like a dress rehearsal for our infrastructure! đ
What is Terraform Plan?
The terraform plan
command is a crucial step in the Terraform workflow. It does a few important things:
- It checks your configuration against the current state of your infrastructure.
- It determines what changes need to be made to achieve the desired state described in your configuration.
- It presents a detailed plan of what actions Terraform will take when you apply your configuration.
Think of it as Terraform saying, âHereâs what Iâm planning to do. Does this look good to you?â đ¤
Running Terraform Plan
Letâs run the plan command and see what Terraform has in store for us:
- Make sure youâre in the directory containing your Terraform files.
- Run the following command:
|
|
Interpreting the Plan Output
The output of terraform plan
can be quite lengthy, especially for larger infrastructures. Hereâs a breakdown of what youâll see:
-
Refreshing State: Terraform checks the current state of any existing resources.
-
Planned Changes: This is the main part of the output. It shows what Terraform is planning to do:
+
means Terraform will create this resource-
means Terraform will destroy this resource~
means Terraform will modify this resource
-
Plan Summary: At the end, youâll see a summary of the planned changes.
Hereâs an example of what you might see:
|
|
In this example, Terraform is planning to create 7 new resources, including a resource group and a virtual network.
Understanding the Plan
Letâs break down what weâre seeing:
- The
+
signs indicate that all these resources will be created. - Some values, like
id
, show â(known after apply)â. This means Terraform canât know these values until the resources are actually created. - The plan shows the exact values that will be used for each resource attribute.
What to Look for in the Plan
When reviewing the plan, pay attention to:
- Are all the expected resources there?
- Are the resource names and attributes correct?
- Are there any unexpected changes or deletions?
The plan is your chance to catch any mistakes before Terraform makes changes to your real infrastructure. Itâs like a safety net for your deployment! đĽ
Best Practices
- Always run
terraform plan
before applying changes. - Review the plan output carefully, especially for large or critical infrastructures.
- If something doesnât look right, stop and review your configuration before proceeding.
- Consider saving the plan output to a file for review or approval in team settings:
This creates a file named
1
terraform plan -out=tfplan
tfplan
that you can later apply withterraform apply tfplan
.
Beautiful work, team! đ Weâve now seen exactly what Terraform is planning to do with our infrastructure. In the next section, weâll take the exciting step of applying our configuration and watching our Azure resources come to life. Ready to make it happen? Letâs go! đ
Applying Our Terraform Configuration
Weâve planned, weâve prepared, and now itâs time for the main event - applying our Terraform configuration! This is where the magic happens, where our code transforms into real, living infrastructure in Azure. Excited? Letâs dive in!
What is Terraform Apply?
The terraform apply
command is where Terraform takes the plans weâve made and turns them into reality. Itâs like pressing the âMake it so!â button on your infrastructure. đ
Hereâs what happens when you run terraform apply
:
- Terraform refreshes the state to make sure it has the most up-to-date information about your existing infrastructure.
- It creates a new plan (just like
terraform plan
did). - It asks for your confirmation.
- If you confirm, it goes ahead and makes the necessary changes to your infrastructure.
Running Terraform Apply
Alright, letâs make it happen:
- Make sure youâre in the directory containing your Terraform files.
- Run the following command:
|
|
What to Expect
After running the command, youâll see output similar to what you saw with terraform plan
. Terraform will show you the planned changes and ask for confirmation:
|
|
This is your last chance to review the changes before theyâre applied. Take a deep breath, double-check that everything looks good, and if youâre ready, type yes
and hit Enter.
Watching the Magic Happen
Once you confirm, Terraform will start creating your resources. Youâll see output like this:
|
|
Terraform creates resources in the order determined by its dependency graph, so you might see some resources being created before others.
Completion and Outputs
Once all resources are created, youâll see a completion message:
|
|
The outputs we defined earlier are displayed here, giving us easy access to important information about our new infrastructure.
What Just Happened?
Letâs take a moment to appreciate what weâve accomplished:
- Weâve created a resource group in Azure.
- Inside that resource group, weâve set up a virtual network with a subnet.
- Weâve created a network security group with a rule allowing RDP access.
- Weâve provisioned a Windows virtual machine, complete with a network interface.
All of this from just a few configuration files and a single command. How good is that? đ
Best Practices
- Always run
terraform plan
beforeterraform apply
to avoid surprises. - In production environments, consider using the
-auto-approve
flag with caution, or better yet, integrate Terraform with a CI/CD pipeline for controlled, automated deployments. - After applying, take a moment to verify your resources in the Azure portal or using Azure CLI.
- Keep your state file safe - itâs crucial for Terraform to keep track of your infrastructure.
Troubleshooting
If something goes wrong during the apply process, donât panic! Terraform will output error messages that can help you identify and fix the issue. Common problems include:
- Insufficient permissions in your Azure subscription
- Resource name conflicts (if resources already exist)
- Exceeded Azure quotas or limits
If you encounter any issues, review the error message, make necessary adjustments to your configuration or Azure settings, and try again.
Congratulations, team! đ Youâve just deployed real infrastructure to Azure using Terraform. Take a moment to let that sink in - youâre now officially infrastructure-as-code practitioners!
In our next section, weâll verify our newly created Azure resources and make sure everything is set up correctly. Ready to admire your handiwork? Letâs keep going! đ
Verifying Our Azure Resources
Weâve just conjured up some Azure resources using Terraform, and now itâs time to make sure everything appeared exactly as we intended. Itâs like checking your work after a spell - always a good idea! Letâs explore two ways to verify our newly created Azure resources.
Method 1: Using the Azure Portal
The Azure Portal provides a visual way to inspect our resources. Hereâs how to do it:
- Open your web browser and navigate to https://portal.azure.com
- Log in with your Azure credentials
- In the search bar at the top, type âResource groupsâ and select it from the dropdown
- Look for the resource group we created (remember, we named it âmyTFResourceGroupâ)
- Click on the resource group to see all the resources inside it
You should see something like this:
- Resource group: myTFResourceGroup
- Virtual network: myTFVNet
- Network security group: myTFNSG
- Network interface: myTFNIC
- Virtual machine: myTFVM
Click on each resource to inspect its details. Make sure everything matches what we specified in our Terraform configuration.
Method 2: Using Azure CLI
For those who prefer the command line (and itâs a good skill to have!), we can use Azure CLI to verify our resources. First, make sure youâre logged in:
|
|
Then, letâs check our resources:
-
List the resource group:
1
az group show --name myTFResourceGroup
-
List the virtual network:
1
az network vnet show --resource-group myTFResourceGroup --name myTFVNet
-
Check the subnet:
1
az network vnet subnet show --resource-group myTFResourceGroup --vnet-name myTFVNet --name myTFSubnet
-
Inspect the network security group:
1
az network nsg show --resource-group myTFResourceGroup --name myTFNSG
-
View the virtual machine details:
1
az vm show --resource-group myTFResourceGroup --name myTFVM
These commands will output JSON-formatted information about each resource. It might look a bit overwhelming at first, but you can scan through it to verify key details like names, locations, and configurations.
What to Look For
When verifying your resources, pay attention to:
- Resource Names: Do they match what we specified in our Terraform config?
- Location: Are all resources in Australia East as we intended?
- Virtual Network and Subnet: Are the address spaces correct?
- Network Security Group: Is the RDP rule (port 3389) properly configured?
- Virtual Machine: Is it the correct size and using the right Windows image?
Terraform State
Remember, Terraform keeps track of the resources it manages in the state file. You can also use Terraform to show resource details:
|
|
This command displays the current state of your infrastructure as Terraform sees it. Itâs a great way to cross-reference with what you see in Azure.
What If Somethingâs Not Right?
If you spot any discrepancies between what you expected and whatâs actually in Azure, donât worry! Hereâs what you can do:
- Double-check your Terraform configuration files for any mistakes
- Run
terraform plan
again to see if Terraform detects any differences - If needed, make adjustments to your configuration and run
terraform apply
again
Remember, with infrastructure as code, itâs easy to make changes and keep your infrastructure in the desired state.
Beautiful work, team! đ Youâve not only created Azure resources with Terraform but also verified that theyâre set up correctly. Thatâs some top-notch infrastructure management right there!
In our next section, weâll explore how to make changes to our infrastructure using Terraform. Ready to flex those modification muscles? Letâs keep the momentum going! đ
Making Changes to Our Infrastructure
Youâve created your infrastructure, youâve verified itâs all there - but what happens when you need to make a change? Thatâs where the real power of Infrastructure as Code shines. Letâs dive in and see how Terraform handles modifications to our existing setup.
The Scenario
Letâs say our application is becoming more popular (congrats!), and we need to beef up our VM a bit. Weâre going to change the VM size from Standard_F2 to Standard_F4, giving us more compute power to handle the increased load.
Modifying Our Terraform Configuration
- Open your
variables.tf
file. - Find the
vm_size
variable and change its default value:
|
|
Thatâs it! This simple change tells Terraform that we want a bigger VM.
Planning the Changes
Before we apply this change, letâs see what Terraform plans to do:
- Save your changes to
variables.tf
. - In your terminal, run:
|
|
You should see output similar to this:
|
|
The ~
symbol indicates that Terraform will modify an existing resource rather than create a new one or destroy an old one.
Applying the Changes
If the plan looks good, letâs apply these changes:
|
|
Terraform will show you the plan again and ask for confirmation. Type yes
and hit Enter.
Youâll see output showing Terraform updating the VM:
|
|
Understanding What Just Happened
Letâs break down what Terraform did:
- It compared the desired state (our updated configuration) with the current state (the existing infrastructure).
- It identified that only the VM size needed to change.
- It updated the VM in place, without affecting other aspects of the VM or other resources.
This is the beauty of Terraform - it makes only the necessary changes to bring your infrastructure in line with your configuration.
Verifying the Change
Letâs double-check that our change took effect:
Using Azure CLI:
|
|
You should see âStandard_F4â as the output.
The Power of Infrastructure as Code
What weâve just done demonstrates the real power of Infrastructure as Code:
- Predictability: We saw exactly what would change before applying it.
- Minimal Disruption: Only the necessary resource was modified.
- Version Control: If weâre using git, this change is now tracked in our repository.
- Repeatability: We can make this same change across multiple environments easily.
Best Practices for Making Changes
- Always run
terraform plan
beforeterraform apply
to avoid surprises. - Keep your Terraform configuration in version control to track changes over time.
- For larger changes, consider using Terraform workspaces or separate configuration sets for different environments.
- Regularly update your Terraform version and provider versions to access new features and bug fixes.
Congratulations, you infrastructure-modifying maestro! đ Youâve successfully updated your Azure infrastructure using Terraform. This ability to easily and safely make changes is what makes Infrastructure as Code so powerful in managing cloud resources.
In our next and final section, weâll look at how to clean up our resources when weâre done. Ready to wrap this up? Letâs go! đ
Cleaning Up: Destroying Our Infrastructure
Weâve come to the final stage of our Terraform journey - cleaning up our resources. Itâs like leaving a campsite cleaner than you found it, but in the cloud! Letâs learn how to responsibly tear down the infrastructure weâve built.
Why Clean Up is Important
Cleaning up unused resources is crucial for several reasons:
- Cost Management: Azure charges for resources even when theyâre not actively used. Deleting unused resources saves money.
- Security: Reducing your infrastructure footprint minimizes potential security risks.
- Resource Limits: Azure subscriptions have limits on the number of resources you can create. Cleaning up frees up your quota.
- Cleanliness: A tidy Azure subscription is easier to manage and understand.
The Terraform Destroy Command
Terraform makes it easy to remove all the resources weâve created with a single command: terraform destroy
. This command does exactly what it sounds like - it destroys all the resources defined in your Terraform configuration.
Hereâs how to use it:
- Make sure youâre in the directory containing your Terraform files.
- Run the following command:
|
|
What to Expect
When you run terraform destroy
, hereâs what happens:
- Terraform plans the destruction of resources, similar to how
terraform plan
works. - It shows you a summary of what will be destroyed.
- It asks for your confirmation before proceeding.
Youâll see output like this:
|
|
This is your last chance to review whatâs about to be deleted. Double-check that youâre in the right directory and that youâre okay with destroying these resources.
If youâre sure, type yes
and hit Enter.
Watching the Cleanup
Terraform will then proceed to destroy your resources. Youâll see output like this:
|
|
Terraform destroys resources in the reverse order of their dependencies, ensuring everything is cleaned up properly.
Verifying the Cleanup
After Terraform finishes, itâs a good idea to double-check that everything was removed:
- Log into the Azure portal
- Look for the resource group we created (âmyTFResourceGroupâ)
- It should no longer exist
You can also use Azure CLI to verify:
|
|
This should return an error saying the resource group wasnât found.
Best Practices for Cleanup
- Always Review the Plan: Before confirming the destroy operation, carefully review what Terraform plans to delete.
- Use Targeted Destroy: If you only want to remove specific resources, you can use
terraform destroy -target=RESOURCE_TYPE.NAME
for more granular control. - Version Control: Keep your Terraform configurations in version control. Even after destroying resources, youâll have a record of what was created.
- Backup State: Before destroying, consider backing up your Terraform state file. This can be helpful for auditing or if you need to recreate the infrastructure later.
A Note on Terraform State
After destroying your resources, your Terraform state file (terraform.tfstate
) will be updated to reflect that no resources are currently managed. If you run terraform show
now, you should see no resources listed.
Wrapping Up
Beautiful work đ Youâve now completed the full lifecycle of infrastructure management with Terraform:
- Writing configuration
- Planning changes
- Applying configuration
- Modifying resources
- And finally, cleaning everything up
Youâve got the skills to create, manage, and responsibly remove cloud infrastructure using code. Thatâs a powerful toolset for any cloud engineer!
Remember, in real-world scenarios, be extra cautious with destroy commands, especially in shared or production environments. Always double-check what youâre about to remove.
Congratulations on completing this Terraform journey! Youâre well on your way to becoming a true Infrastructure as Code expert. Keep practicing, keep learning, and most importantly, have fun building amazing things in the cloud! đđ
Conclusion
Congratulations Youâve just completed your first end-to-end Terraform project on Azure. Letâs take a moment to appreciate how far youâve come:
- Youâve set up a Terraform configuration for Azure resources
- Learned how to use variables to make your config flexible
- Planned and applied your infrastructure changes
- Modified existing resources using Terraform
- And responsibly cleaned up your resources
Youâve not just learned about Terraform - youâve experienced the full lifecycle of infrastructure as code. Thatâs no small feat!
Key Takeaways
- Infrastructure as Code makes managing cloud resources more efficient and repeatable
- Terraform allows you to define, create, modify, and destroy Azure resources using code
- Always plan before you apply to avoid surprises
- Cleaning up unused resources is crucial for cost management and security
Whatâs Next?
But wait, thereâs more! đ As youâve been working through this tutorial, you might have noticed Terraform referring to something called âstateâ. What is this mysterious state, and why is it so important?
In our next article, âUnderstanding Terraform State Management in Azureâ, weâll dive deep into this crucial concept. Youâll learn:
- What Terraform state is and why itâs essential
- How Terraform uses state to track your resources
- Best practices for managing state in Azure
- How to work with remote state for team collaboration
State management is a key part of working with Terraform, especially in team environments or when dealing with larger, more complex infrastructures. Itâs the secret sauce that allows Terraform to know what itâs managing and how to make changes efficiently.
So, pat yourself on the back for a job well done, take a quick break, and when youâre ready, join us for the next exciting chapter in your Terraform journey. The world of infrastructure as code is at your fingertips, and youâre just getting started!
Keep calm and Terraform on! đđťđ