Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Mastering Terraform
Mastering Terraform

Mastering Terraform: A practical guide to building and deploying infrastructure on AWS, Azure, and GCP

Arrow left icon
Profile Icon Mark Tinderholt
Arrow right icon
Free Trial
Full star icon Full star icon Full star icon Full star icon Full star icon 5 (18 Ratings)
Paperback Jul 2024 494 pages 1st Edition
eBook
Can$12.99 Can$50.99
Paperback
Can$63.99
Subscription
Free Trial
Arrow left icon
Profile Icon Mark Tinderholt
Arrow right icon
Free Trial
Full star icon Full star icon Full star icon Full star icon Full star icon 5 (18 Ratings)
Paperback Jul 2024 494 pages 1st Edition
eBook
Can$12.99 Can$50.99
Paperback
Can$63.99
Subscription
Free Trial
eBook
Can$12.99 Can$50.99
Paperback
Can$63.99
Subscription
Free Trial

What do you get with a Packt Subscription?

Free for first 7 days. $19.99 p/m after that. Cancel any time!
Product feature icon Unlimited ad-free access to the largest independent learning library in tech. Access this title and thousands more!
Product feature icon 50+ new titles added per month, including many first-to-market concepts and exclusive early access to books as they are being written.
Product feature icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Product feature icon Thousands of reference materials covering every tech concept you need to stay up to date.
Subscribe now
View plans & pricing
Table of content icon View table of contents Preview book icon Preview Book

Mastering Terraform

Understanding Terraform Architecture

At its core, Terraform is a simple command-line program that evaluates source code, which describes what a desired state should look like, compares it against what the actual state is, constructs a plan to transform the actual state into the desired state, and can execute the plan. But don’t let its perceived simplicity fool you. Terraform’s internal complexity manifests itself in its external simplicity.

Terraform is a large, source-available project written in Go that maintains the command-line executable. It provides baseline functionality such as HashiCorp Configuration Language (HCL) parsing, state management, plan creation, and execution.

Terraform is extremely powerful, yet ironically, it does very little by itself. But here’s the exciting part: Terraform’s superpower comes from its extensibility, a power that is not limited to its creators. The actual Terraform executable, by itself, can’t do much...

Understanding Terraform architecture

The biggest differentiator of Terraform is that, well, Terraform plans ahead. Let’s look at how Terraform handles planning in detail.

The plan

When working with Terraform, you will be following a process where Terraform is used to analyze the existing environment. In doing this analysis, Terraform is determining what (if any) changes in the code need to be applied to the actual environment to bring it up to date. Terraform itemizes these changes as actions within the plan. While Terraform does this analysis on our behalf, produces the plan, and is fully capable of executing that plan against the environment, we are still responsible for reviewing the plan and determining if the planned changes are what we intended:

Figure 1.1 – Terraform resources are straightforward machines with inputs and outputs

Figure 1.1 – Terraform resources are straightforward machines with inputs and outputs

Terraform represents every component in your environment as a resource in this analysis. Resources...

Understanding Terraform state

Terraform uses the state to remember what was previously provisioned in a given workspace. Some critics of Terraform, when they compare it to AWS CloudFormation or ARM templates, point out that these technologies don’t rely on this concept of maintaining state in an externalized file. Of course, this is only true because these tools only support a single target platform and can tightly couple to the proprietary nature in which those platforms maintain state. However, Terraform—with its flexible plugin architecture—can’t assume anything about the platform and the resources that it provisions to each target platform. Therefore, Terraform needs to drop to the lowest common denominator and ensure that it knows what it has provisioned before in a uniform and consistent fashion.

This approach to maintaining the state provides a couple of benefits. First, it uniformly records what Terraform has provisioned across platforms that...

Understanding how to build and consume modules

One of Terraform’s most powerful capabilities is its ease of organizing and packaging reusable code, which increases the maintainability of your code base and improves the reusability of common patterns in your architecture.

Traditional developers have it easy—you must simply create a new method to encapsulate a reusable code block. In other IaC tools, doing the same thing is a challenge. In Terraform, all you need is a new folder.

Terraform scopes every module within a folder. When you run terraform init, Terraform transforms the current working directory into the root module of the workspace. You can use modules stored in other folders within the same repository just by using a relative path to reference the module. It is a standard convention within the Terraform community for storing local modules in a modules directory near the root module’s directory.

Consider this folder structure:

  &...

Understanding how to use the CLI effectively

Now that we understand Terraform’s core architecture, let’s examine its CLI and how to interact with it. There are many different commands, but we’ll focus on the important ones for implementing the core Terraform workflow. I’d encourage you to explore HashiCorp’s documentation for some of the more obscure ones, and later in Chapter 17, when we discuss managing existing environments using Terraform, we’ll be covering some more commands useful in that context.

init

This is an important command and probably the first one you will ever execute when working with Terraform. The reason is that Terraform works within a working directory instead of other tools that operate on a single file (such as ARM or CloudFormation) or an entry point file (such as Ansible). Terraform also relies on hidden directories to load important context about the workspace. This approach is very similar to how Git works...

Summary

In this chapter, we took an in-depth look at Terraform’s architecture. We primarily focused on two critical architectural components: state and modularity. Having a sound understanding of Terraform’s architecture is vital for you to be able to use Terraform to its fullest effectively. Finally, we ended by looking at Terraform’s CLI, which will enable you to, when you’re ready, integrate Terraform with your own CI/CD pipelines. In the next chapter, we will explore HCL so that we can lay the foundation on which we can start building IaC using Terraform.

Left arrow icon Right arrow icon
Download code icon Download Code

Key benefits

  • Build comprehensive end-to-end solutions with Terraform using VMs, Kubernetes, and Serverless
  • Integrate Terraform with other HashiCorp products and common tools such as Packer, Docker, Kubernetes, and Helm
  • Streamline your operations using Gitflow powered by GitHub Actions CI/CD pipelines
  • Purchase of the print or Kindle book includes a free PDF eBook

Description

Advancements made in cloud technology and automation tools have led to increased challenges in defining and managing your infrastructure or app environment as code on your chosen cloud platform, integrating security, managing microservices complexity, and so on. This book takes a learning-by-doing approach to teach you how to employ Terraform features to develop efficient cloud infrastructure using real-world scenarios and best practices. The book begins by introducing you to Terraform's architecture, both as a command-line tool and a programming language, HashiCorp Configuration Language (HCL). You’ll discover best practices, usage, and architectural patterns and implement Terraform on virtual machines (VMs), Docker/Kubernetes, serverless, and multiple cloud platforms such as AWS, Azure, and GCP. The chapters also show you how to industrialize your CI/CD pipeline by integrating Terraform with other popular technologies to build, provision, deploy, and manage cloud infrastructure. You’ll gain a clear understanding of security, monitoring, troubleshooting, and cost optimization and be able to apply the concepts you’ve learned when preparing for Terraform Associate certification exams. By the end of this book, you’ll be equipped to confidently build, automate, and deliver your infrastructure and CI/CD pipelines in cloud-based applications.

Who is this book for?

This book is for Devops engineers, cloud engineers, platform engineers, infrastructure engineers, site reliability engineers, developers, and cloud architects who want to utilize Terraform to automate their cloud infrastructures and streamline software delivery. Prior knowledge of cloud architecture, infrastructure, and platforms, as well as Terraform basics, will help you understand the topics present in this book.

What you will learn

  • Explore Terraform architecture and configurations in depth
  • Integrate Packer with Terraform for VM-based solutions
  • Containerize apps with Docker and Kubernetes
  • Explore GitOps and CI/CD deployment patterns
  • Transform existing applications into serverless architectures
  • Migrate and modernize legacy apps for the cloud
  • Implement Terraform on AWS, Azure, and GCP
  • Use Terraform with teams of varying size and responsibility

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Jul 26, 2024
Length: 494 pages
Edition : 1st
Language : English
ISBN-13 : 9781835086018
Languages :
Tools :

What do you get with a Packt Subscription?

Free for first 7 days. $19.99 p/m after that. Cancel any time!
Product feature icon Unlimited ad-free access to the largest independent learning library in tech. Access this title and thousands more!
Product feature icon 50+ new titles added per month, including many first-to-market concepts and exclusive early access to books as they are being written.
Product feature icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Product feature icon Thousands of reference materials covering every tech concept you need to stay up to date.
Subscribe now
View plans & pricing

Product Details

Publication date : Jul 26, 2024
Length: 494 pages
Edition : 1st
Language : English
ISBN-13 : 9781835086018
Languages :
Tools :

Packt Subscriptions

See our plans and pricing
Modal Close icon
$19.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
$199.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just Can$6 each
Feature tick icon Exclusive print discounts
$279.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just Can$6 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total Can$ 203.97
Mastering Terraform
Can$63.99
Solutions Architect's Handbook
Can$75.99
The Linux DevOps Handbook
Can$63.99
Total Can$ 203.97 Stars icon
Banner background image

Table of Contents

26 Chapters
Part 1: Foundations of Terraform Chevron down icon Chevron up icon
Chapter 1: Understanding Terraform Architecture Chevron down icon Chevron up icon
Chapter 2: Using HashiCorp Configuration Language Chevron down icon Chevron up icon
Chapter 3: Harnessing HashiCorp Utility Providers Chevron down icon Chevron up icon
Part 2: Concepts of Cloud Architecture and Automation Chevron down icon Chevron up icon
Chapter 4: Foundations of Cloud Architecture – Virtual Machines and Infrastructure-as-a-Services Chevron down icon Chevron up icon
Chapter 5: Beyond VMs – Core Concepts of Containers and Kubernetes Chevron down icon Chevron up icon
Chapter 6: Connecting It All Together – GitFlow, GitOps, and CI/CD Chevron down icon Chevron up icon
Part 3: Building Solutions on AWS Chevron down icon Chevron up icon
Chapter 7: Getting Started on AWS – Building Solutions with AWS EC2 Chevron down icon Chevron up icon
Chapter 8: Containerize with AWS – Building Solutions with AWS EKS Chevron down icon Chevron up icon
Chapter 9: Go Serverless with AWS – Building Solutions with AWS Lambda Chevron down icon Chevron up icon
Part 4: Building Solutions on Azure Chevron down icon Chevron up icon
Chapter 10: Getting Started on Azure – Building Solutions with Azure Virtual Machines Chevron down icon Chevron up icon
Chapter 11: Containerize on Azure – Building Solutions with Azure Kubernetes Service Chevron down icon Chevron up icon
Chapter 12: Go Serverless on Azure – Building Solutions with Azure Functions Chevron down icon Chevron up icon
Part 5: Building Solutions on Google Cloud Chevron down icon Chevron up icon
Chapter 13: Getting Started on Google Cloud – Building Solutions with GCE Chevron down icon Chevron up icon
Chapter 14: Containerize on Google Cloud – Building Solutions with GKE Chevron down icon Chevron up icon
Chapter 15: Go Serverless on Google Cloud – Building Solutions with Google Cloud Functions Chevron down icon Chevron up icon
Part 6: Day 2 Operations and Beyond Chevron down icon Chevron up icon
Chapter 16: Already Provisioned? Strategies for Importing Existing Environments Chevron down icon Chevron up icon
Chapter 17: Managing Production Environments with Terraform Chevron down icon Chevron up icon
Chapter 18: Looking Ahead – Certification, Emerging Trends, and Next Steps Chevron down icon Chevron up icon
Index Chevron down icon Chevron up icon
Other Books You May Enjoy Chevron down icon Chevron up icon

Customer reviews

Top Reviews
Rating distribution
Full star icon Full star icon Full star icon Full star icon Full star icon 5
(18 Ratings)
5 star 100%
4 star 0%
3 star 0%
2 star 0%
1 star 0%
Filter icon Filter
Top Reviews

Filter reviews by




Chris Williams Sep 19, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Mark's book is an absolute game-changer for anyone working with Terraform: whether you’re a seasoned DevOps engineer or just getting started with infrastructure as code. This book stands out with its clear, concise, and practical approach to mastering Terraform, making complex topics accessible and understandable.What sets this book apart is its hands-on, real-world examples that take you beyond the basics and into advanced Terraform concepts. Tinderholt does an exceptional job of breaking down sophisticated modules, state management, and best practices that are critical for managing scalable and reliable infrastructure. His deep insights into optimizing Terraform workflows and handling common challenges make this book an invaluable resource.Each chapter builds on the last, guiding you through everything from setting up your environment to deploying complex, multi-cloud architectures. The inclusion of tips and tricks learned from years of real-world experience adds incredible value, helping readers avoid common pitfalls and adopt best practices.“Mastering Terraform” is not just a technical manual; it’s a strategic guide that empowers you to leverage Terraform to its full potential. Mark Tinderholt’s expertise and passion for the subject shine through, making this a must-have book for your DevOps library. Highly recommended!
Amazon Verified review Amazon
Rafal Sep 21, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
The book gives tons of advice on how to apply Terraform in real life scenarios: what to watch out for, what particular constructs are best for and how to avoid pitfalls. You can tell that this advice is backed by years of experience. I definitely recommend the book!
Amazon Verified review Amazon
Carlos Carballo Jul 31, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
I am really enjoying this book. It has been written in a way that very complicated matters seem easy. The AKS portion has really caught my attention!!Thank u Mark!!!!
Amazon Verified review Amazon
LK Aug 07, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Finally comprehensive, easy to read, well presented, up to date and including gitflow. Well worth getting!
Amazon Verified review Amazon
Jblaaa Oct 22, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Mark's does a great job explaining all the foundational elements of Terraform as well as provide great examples that can be applied to the real world. There is plenty of theory as well as applicable examples that helps the reader understand the 'why' behind the application of Terraform. Terraform workflows are Mark does a great job of running through the pros and cons of several popular workflows that can be found in the wild to help the reader understand and choose appropriately. Highly recommend anyone new or old to Terraform.
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

What is included in a Packt subscription? Chevron down icon Chevron up icon

A subscription provides you with full access to view all Packt and licnesed content online, this includes exclusive access to Early Access titles. Depending on the tier chosen you can also earn credits and discounts to use for owning content

How can I cancel my subscription? Chevron down icon Chevron up icon

To cancel your subscription with us simply go to the account page - found in the top right of the page or at https://subscription.packtpub.com/my-account/subscription - From here you will see the ‘cancel subscription’ button in the grey box with your subscription information in.

What are credits? Chevron down icon Chevron up icon

Credits can be earned from reading 40 section of any title within the payment cycle - a month starting from the day of subscription payment. You also earn a Credit every month if you subscribe to our annual or 18 month plans. Credits can be used to buy books DRM free, the same way that you would pay for a book. Your credits can be found in the subscription homepage - subscription.packtpub.com - clicking on ‘the my’ library dropdown and selecting ‘credits’.

What happens if an Early Access Course is cancelled? Chevron down icon Chevron up icon

Projects are rarely cancelled, but sometimes it's unavoidable. If an Early Access course is cancelled or excessively delayed, you can exchange your purchase for another course. For further details, please contact us here.

Where can I send feedback about an Early Access title? Chevron down icon Chevron up icon

If you have any feedback about the product you're reading, or Early Access in general, then please fill out a contact form here and we'll make sure the feedback gets to the right team. 

Can I download the code files for Early Access titles? Chevron down icon Chevron up icon

We try to ensure that all books in Early Access have code available to use, download, and fork on GitHub. This helps us be more agile in the development of the book, and helps keep the often changing code base of new versions and new technologies as up to date as possible. Unfortunately, however, there will be rare cases when it is not possible for us to have downloadable code samples available until publication.

When we publish the book, the code files will also be available to download from the Packt website.

How accurate is the publication date? Chevron down icon Chevron up icon

The publication date is as accurate as we can be at any point in the project. Unfortunately, delays can happen. Often those delays are out of our control, such as changes to the technology code base or delays in the tech release. We do our best to give you an accurate estimate of the publication date at any given time, and as more chapters are delivered, the more accurate the delivery date will become.

How will I know when new chapters are ready? Chevron down icon Chevron up icon

We'll let you know every time there has been an update to a course that you've bought in Early Access. You'll get an email to let you know there has been a new chapter, or a change to a previous chapter. The new chapters are automatically added to your account, so you can also check back there any time you're ready and download or read them online.

I am a Packt subscriber, do I get Early Access? Chevron down icon Chevron up icon

Yes, all Early Access content is fully available through your subscription. You will need to have a paid for or active trial subscription in order to access all titles.

How is Early Access delivered? Chevron down icon Chevron up icon

Early Access is currently only available as a PDF or through our online reader. As we make changes or add new chapters, the files in your Packt account will be updated so you can download them again or view them online immediately.

How do I buy Early Access content? Chevron down icon Chevron up icon

Early Access is a way of us getting our content to you quicker, but the method of buying the Early Access course is still the same. Just find the course you want to buy, go through the check-out steps, and you’ll get a confirmation email from us with information and a link to the relevant Early Access courses.

What is Early Access? Chevron down icon Chevron up icon

Keeping up to date with the latest technology is difficult; new versions, new frameworks, new techniques. This feature gives you a head-start to our content, as it's being created. With Early Access you'll receive each chapter as it's written, and get regular updates throughout the product's development, as well as the final course as soon as it's ready.We created Early Access as a means of giving you the information you need, as soon as it's available. As we go through the process of developing a course, 99% of it can be ready but we can't publish until that last 1% falls in to place. Early Access helps to unlock the potential of our content early, to help you start your learning when you need it most. You not only get access to every chapter as it's delivered, edited, and updated, but you'll also get the finalized, DRM-free product to download in any format you want when it's published. As a member of Packt, you'll also be eligible for our exclusive offers, including a free course every day, and discounts on new and popular titles.