Make changes to your infrastructure
Now that your infrastructure is deployed, let's discuss how to make changes to it.
Making changes to Terraform code
- Making changes to vanilla Terraform code
- Making changes to Terragrunt code
- Making changes with Terraform Cloud or Terraform Enterprise
Making changes to vanilla Terraform code
- (Optional) Update your configuration: One type of change you could do in your Terraform code (in the - .tffiles) is to update the arguments you're passing to the service. For example, perhaps you update from one NAT Gateway:- module "vpc" {
 source = "git@github.com:gruntwork-io/terraform-aws-service-catalog.git//modules/networking/vpc?ref=v0.0.1"
 # ... (other args ommitted for readability) ...
 num_nat_gateways = 1
 }- To 3 NAT Gateways for high availability: - module "vpc" {
 source = "git@github.com:gruntwork-io/terraform-aws-service-catalog.git//modules/networking/vpc?ref=v0.0.1"
 # ... (other args ommitted for readability) ...
 num_nat_gateways = 3
 }
- (Optional) Update the Service Catalog version: Another type of change you might make is to update the version of the Service Catalog you're using. For example, perhaps you update from version - v0.0.1:- module "vpc" {
 source = "git@github.com:gruntwork-io/terraform-aws-service-catalog.git//modules/networking/vpc?ref=v0.0.1"
 # ... (other args omitted for readability) ...
 }- To version - v0.0.2:- module "vpc" {
 source = "git@github.com:gruntwork-io/terraform-aws-service-catalog.git//modules/networking/vpc?ref=v0.0.2"
 # ... (other args omitted for readability) ...
 }
note
Whenever changing version numbers, make sure to read the release
notes, especially if it's a backwards
incompatible release (e.g., v0.0.1 -> v0.1.0), to avoid errors and outages (see maintenance and
versioning for details)!
- Deploy. Once you've made your changes, you can re-run - terraform applyto deploy them:- terraform apply- Since Terraform maintains state, it will now update your infrastructure rather than deploying something new. As part of running - apply, Terraform will show you the plan output, which will show you what's about to change before changing it. Make sure to scan the plan output carefully to catch potential issues, such as something important being deleted that shouldn't be (e.g., a database!).
Making changes to Terragrunt code
- (Optional) Update your configuration: One type of change you could do in your Terragrunt code (in the - terragrunt.hclfiles) is to update the arguments you're passing to the service. For example, perhaps you update from one NAT Gateway:- terraform {
 source = "git@github.com:gruntwork-io/terraform-aws-service-catalog.git//modules/networking/vpc?ref=v0.0.1"
 }
 inputs = {
 # ... (other args omitted for readability) ...
 num_nat_gateways = 1
 }- To 3 NAT Gateways for high availability: - terraform {
 source = "git@github.com:gruntwork-io/terraform-aws-service-catalog.git//modules/networking/vpc?ref=v0.0.1"
 }
 inputs = {
 # ... (other args omitted for readability) ...
 num_nat_gateways = 3
 }
- (Optional) Update the Service Catalog version: Another type of change you might make is to update the version of the Service Catalog you're using. For example, perhaps you update from version - v0.0.1:- terraform {
 source = "git@github.com:gruntwork-io/terraform-aws-service-catalog.git//modules/networking/vpc?ref=v0.0.1"
 }- To version - v0.0.2:- terraform {
 source = "git@github.com:gruntwork-io/terraform-aws-service-catalog.git//modules/networking/vpc?ref=v0.0.2"
 }
note
Whenever changing version numbers, make sure to read the release
notes, especially if it's a backwards
incompatible release (e.g., v0.0.1 -> v0.1.0), to avoid errors and outages (see maintenance and
versioning for details)!
- Deploy. Once you've made your changes, you can re-run - terragrunt applyto deploy them:- terragrunt apply- Since Terraform maintains state, it will now update your infrastructure rather than deploying something new. As part of running - apply, Terraform will show you the plan output, which will show you what's about to change before changing it. Make sure to scan the plan output carefully to catch potential issues, such as something important being deleted that shouldn't be (e.g., a database!).
Making changes with Terraform Cloud or Terraform Enterprise
(Documentation coming soon. If you need help with this ASAP, please contact support@gruntwork.io.)
Making changes to Packer templates
- (Optional) Update variables: One type of change you might make is to update the variables you set in your vars file. In particular, you may wish to use a newer version of the Service Catalog for the build. For example, perhaps you update from version - v0.0.1:- {
 "service_catalog_ref": "v0.0.1"
 }- To version - v0.0.2:- {
 "service_catalog_ref": "v0.0.2"
 }- note- Whenever changing version numbers, make sure to read the release notes, especially if it's a backwards incompatible release (e.g., - v0.0.1->- v0.1.0), to avoid errors and outages (see maintenance and versioning for details)!
- (Optional) Update your custom Packer template: If you made a copy of one of of the Packer templates, you can of course also make updates to your own template. 
- Build. Once you've made your changes, you can re-run - packer buildto build a new AMI:- packer build -var-file=eks-vars.json eks-node-al2.pkr.hcl
- Deploy. Once you've built a new AMI, you'll need to make changes to your Terraform code and deploy it.