• Stars
    star
    185
  • Rank 208,271 (Top 5 %)
  • Language HCL
  • Created about 7 years ago
  • Updated about 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Exercise files for my Pluralsight course.

Deep-Dive-Terraform

Welcome to Terraform - Deep Dive version 2. These exercise files are meant to accompany my course on Pluralsight. The course was developed using version 0.12.x of Terraform. As far as I know there are no coming changes in 0.13 or newer that will significantly impact the validity of these exercise files. But I also don't control all the plug-ins, providers, and modules used by the configurations.

If you're looking for the older version of the course, that is still available on the v1 branch. I am no longer maintaining it, but I thought I would keep it around for posterity.

AWS Account

You are going to need an account where you have FullAdmin permissions. You are going to be creating policies, roles, profiles, VPCs, etc. If you don't have enough permissions in your current environment, then I recommend creating a temporary account to mess around in. In fact, probably do that regardless. You don't want to accidentally mess something up at work because you were trying to learn about Terraform.

You may exceed your EIP address quota when deploying multiple enviornments. You can request an increase through the AWS console in the Services Quotas area, under the Amazon Elastic Compute Cloud category. I recommend setting it to 15 just to be safe. It should be approved almost immediately, but may take 30 minutes to apply. So if you do it now, it should be ready long before you get to that portion of the course.

Using the files

Each folder represents a module from the course and they often build upon each other. Especially, the directory m4 that has the setup for Consul and stores it's data. In each module and subfolder there may be an example of the tfvars file that you use named terraform.tfvars.example. Simply update the contents of the file and rename it terraform.tfvars.

Once you have updated and renamed the tfvars file(s), you can run the commands in the name_commands.txt file, where the name is the name of the module or folder. Be sure to follow the commands in order, and be cognizant of what directory is being used for each command. Or you can just noodle around on the terraform CLI and see what you can discover/break. If you run into an issue, please submit it as such and I will do my best to remediate it.

Line Endings

An issue I have discovered from time to time is that Terraform doesn't much like the Windows style of ending a line with both a Carriage Return (CR) and a Line Feed (LF), commonly referred to as CRLF. If you are experiencing strange parsing issues, change the line ending to be Line Feed (LF) only. In VS Code this can be down by clicking on the CRLF in the lower right corner and changing it to LF.

MONEY!!!

A gentle reminder about cost. The course will have you creating resources in AWS. Some of the resources are not going to be 100% free. In most cases I have tried to use the Free-tier when possible, but in some cases I have elected to use a larger size EC2 instance to demonstrate the possibilities with multiple environments. Additionally, the NAT gateways created by the networking configurations in later modules are not free! They can run about $40 a piece for the month.

When you complete an exercise in the course, be sure to tear down the infrastructure. Just run terraform destroy and approve the destruction to remove all resources from AWS. You should remove infrastructure in the reverse order that it was deployed. Destroy folder applications then networking. You get the idea.

Module 7

The contents of module 7 are all about troubleshooting Terraform. As a consequence, if you try and run the files as they are you will see lots of fun errors. That's the point! In the process of creating trouble, I discovered a bug with how the AWS aws_iam_instance_profile is created/destroyed. That bug might be fixed by the time you try the course, so you might not see the same behavior. The final example of making Terraform panic may also be fixed in newer versions of Terraform. For reference, here's the issue I found to create the crash. If it has been fixed and you still want to see Terraform PANIC, you can search the GitHub issues for a different example or use an older version of Terraform that doesn't have the fix.

Module 8

A special note about module 8. The process has you deploy resources using Jenkins. In order to destroy the infrastructure, kick off a build and select Cancel during the approval stage. Cancelling the process will trigger a destruction of the environment. Don't use this process in real life, you'll end up with some very unhappy Ops folks.

Certification

HashiCorp has released the Terraform Certified Associate certification. You might be wondering if this course fully prepares you for the cert. It does not. Taking this course along with the Terraform - Getting Started course on Pluralsight will meet most of the learning objectives for the certification, but there is no substitute for running the software on your own and hacking away.

I have coauthored a certification guide which you can find on Leanpub. This is an unofficial guide, but I believe in concert with the Pluralsight courses you will be in a good position to sit the exam.

Conclusion

I hope you enjoy taking this course as much as I did creating it. I'd love to hear feedback and suggestions for revisions.

Thanks and happy automating!

Ned

More Repositories

1

Getting-Started-Terraform

Exercise files for my Pluralsight course
HCL
558
star
2

terraform-tuesdays

Demo files for various Terraform Tuesday Examples
HCL
385
star
3

Implementing-Terraform-on-Microsoft-Azure

Code examples for the Pluralsight course Implementing Terraform on Microsoft Azure
HCL
135
star
4

Implementing-Terraform-on-AWS

Exercise files for the Pluralsight course
HCL
64
star
5

Getting-Started-Vault

Shell
59
star
6

Hashicorp-Certified-Vault-Associate-Getting-Started

Exercise files for my course Hashicorp Certified Vault Associate: Getting Started
Shell
40
star
7

Managing-HashiCorp-Vault

HCL
25
star
8

ado-labs-github-actions

Demo files for the Azure DevOps Labs episode about GitHub Actions and Terraform
HCL
21
star
9

CKA-Study-Guide

My personal study guide for the CKA
20
star
10

vault-oidc-github-actions

A demonstration of using GitHub OIDC to authenticate to HashiCorp Vault
HCL
20
star
11

Hashicorp-Certified-Vault-Associate-Vault-Management

Exercise files for my Pluralsight course.
Shell
18
star
12

Terraform-FotD

Terraform Function of the Day
HCL
18
star
13

Azure-Identity-Management

PowerShell
17
star
14

Azure-Information-Protection

PowerShell
17
star
15

vault-policy-testing

Python
16
star
16

advanced-networking-on-aws

Exercise files for the Advanced Networking on AWS course on Pluralsight
Shell
16
star
17

Installing-and-Configuring-HashiCorp-Vault

HCL
15
star
18

Configuring-and-Managing-Microsoft-Azure-Key-Vault

I really feel like the name says it all.
PowerShell
15
star
19

learning-opa-and-terraform

A Tutorial on Using Open Policy Agent with Terraform
Open Policy Agent
14
star
20

hashitalks-aks-pod-id

HCL
11
star
21

PowerShellHelperScripts

Random Helper Scripts in PowerShell
PowerShell
10
star
22

ado-labs-validate-iac

Demo files to accompany the Microsoft Azure DevOps Labs presentation.
HCL
10
star
23

Getting-Started-with-Terraform-Cloud

HCL
10
star
24

Implement-an-AVD-Infrastructure

Exercise files to accompany my Pluralsight course
HCL
9
star
25

Configuring-Encryption-for-Data-at-Rest-in-Microsoft-Azure

PowerShell
8
star
26

azure-swa-hugo-blog

Code to deploy and maintain an Azure Static Webapp running a static web site generated with Hugo and GitHub Actions.
HTML
7
star
27

terraform-azuread-github_oidc

Terraform module to create an Azure AD application, service principal, and federated identity for GitHub-based OIDC authentication.
HCL
7
star
28

terraform-tfe-org-factory

Terraform module to create Terraform Cloud organizations, workspaces, and teams.
HCL
6
star
29

Vault-on-ACI

An implementation of HashiCorp Vault on Azure Container Instances
HCL
6
star
30

Configure-and-Manage-Key-Vault

Exercise files for my Pluralsight course Configure and Manage Key Vault, part of the AZ-500 certification prep.
PowerShell
6
star
31

hashitalks-2023-boundary

Demo code for HashiTalks 2023 Boundary Presentation
HCL
6
star
32

tfc-vault-oidc-example

Example of using workload identity in Terraform Cloud with Vault
HCL
5
star
33

AWS-SysOps-Admin-Assoc-Troubleshoot-Network

Companion exercise files for my Pluralsight course
Shell
5
star
34

Terraforming-with-GitHub-Actions

GitHub repo for my Festive Tech Calendar entry
HCL
4
star
35

terraform-vm

Shell
4
star
36

Configure-Security-Policies

Code examples to accompany the Pluralsight course.
Shell
4
star
37

github-simple-oidc-testing

A simple example of using OIDC with GitHub Actions and Microsoft Azure
HCL
4
star
38

AWS-SysOps-Admin-Assoc-DNS-and-Content-Delivery

Exercise Files for the associated Pluralsight course
Shell
4
star
39

Networking-in-Public-Cloud-Deployments

Code examples for the Networking in Public Cloud Deployments lecture - March 2020
HCL
4
star
40

env0-app-example

HCL
4
star
41

vault-fridays

Shell
3
star
42

tt-folder-example

Folder based multi environment example
HCL
3
star
43

tt-repo-example-prod

Example terraform deployment using repositories per environment
HCL
3
star
44

tt-branch-example

Branch based multi environment example
HCL
3
star
45

terraform-vdc-demo

HCL
3
star
46

terraform-mmsmoa-2019

Demonstration example files for the MMS MOA conference
HCL
3
star
47

dot-net-liverpool

Demo files for Dot Net Liverpool talk
HCL
3
star
48

terraform-azuread-serviceprincipal

Terraform module for creating service principals in Azure AD.
HCL
3
star
49

github-oidc-azure-setup

Setup repository for configuring GitHub Actions and OIDC
HCL
2
star
50

AzureSpeechToTextPowershell

PowerShell Scripts for Azure Speech to Text API
PowerShell
2
star
51

vault-aws-auth

Demo of using AWS IAM auth with HashiCorp Vault
2
star
52

Monitor-Security-with-Azure-Security-Center

Exercise files for my Pluralsight course of same name.
PowerShell
2
star
53

Plan-and-Implement-User-Environments-and-Apps-on-AVD

HCL
2
star
54

Plan-and-Implement-Identity-and-Security-on-AVD

Scripts for my Pluralsight course
HCL
2
star
55

Monitor-and-Maintain-an-AVD-Infrastructure

Repository for my Plurasight course of the same name
HCL
2
star
56

github-oidc-testing

Testing repo for GitHub OIDC to Azure AD
HCL
2
star
57

Configuring-Azure-VM-Clusters-Using-Terraform

Public repository for my A Cloud Guru course
HCL
2
star
58

terraform-cloudinit-native

A Terraform module to generate cloud init file natively without a provider plugin or data source.
HCL
1
star
59

env0-ci-example

Example code for a CI process involving env0
HCL
1
star
60

ansible-playbook-nginx

Ansible playbook to install NGINX locally
Jinja
1
star
61

terraform-azurerm-swapodcast

A Terraform module meant to deploy an Azure Static Web App to host a podcast.
HCL
1
star
62

tt-repo-example-dev

Example terraform deployment using repositories per environment
HCL
1
star
63

vscode-mms2019

Code examples for the VS Code presentation at MMS MOA 2019
JavaScript
1
star
64

IaCTerraformDemo

Files for an Infrastructure as Code demo using Terraform
HCL
1
star
65

env0-terraform-tutorial

Repository to accompany the blog post
HCL
1
star
66

tt-repo-example-staging

Example terraform deployment using repositories per environment
HCL
1
star
67

functional-iac-testing

HCL
1
star
68

azure-philly-aks

Examples for the Azure Philly Meetup
1
star
69

TFSVMDeploy

PowerShell
1
star
70

azure-advent-aks

HCL
1
star
71

terraformProjects

Various Terraform Projects I am kicking around
HCL
1
star
72

AWS-UG-Terraform

HCL
1
star
73

hashiconf-global-opa

Example code for using OPA with Terraform.
Open Policy Agent
1
star
74

Operating-Azure-Stack

Exercise Files to go with the Pluralsight Course
PowerShell
1
star
75

robusta-on-aks

Demo to install Robusta on AKS with Prometheus
HCL
1
star
76

terraform-azurerm-networkdatasource

Data source module for Azure Networking
HCL
1
star
77

aks-storage-testing

FIO testing for different storage types on AKS
Shell
1
star
78

azuredevops-pipeline-agent

Shell
1
star
79

vault-tfc-approle

Example of using AppRole Auth Method with Terraform Cloud
HCL
1
star
80

kthw-terraform-multicloud

Terraform scripts to deploy the necessary infrastructure to do Terrraform the Hard Way on multiple clouds.
HCL
1
star
81

Configuring-Security-Services-and-Policies-in-Microsoft-Azure

Repository for my Pluralsight course
PowerShell
1
star