2017-12-08 11:28:27 -05:00
|
|
|
---
|
|
|
|
layout: guides
|
2017-12-11 17:31:44 -05:00
|
|
|
page_title: Trigger Terraform Enterprise runs
|
2020-03-24 18:36:27 -04:00
|
|
|
sidebar_title: 'Trigger Terraform Enterprise runs'
|
2017-12-08 11:28:27 -05:00
|
|
|
---
|
|
|
|
|
2017-12-11 17:31:44 -05:00
|
|
|
# Create Terraform Enterprise Runs
|
2017-12-08 13:31:00 -05:00
|
|
|
|
2017-12-11 18:10:37 -05:00
|
|
|
Once an image is built and uploaded to an artifact store, the next step is to
|
|
|
|
use this new image. In some cases the image will be downloaded by the dev team
|
|
|
|
and used locally in development, like is often done with VirtualBox images with
|
|
|
|
Vagrant. In most other cases, the new image will be used to provision new
|
|
|
|
infrastructure.
|
2017-12-08 13:31:00 -05:00
|
|
|
|
2017-12-11 18:10:37 -05:00
|
|
|
[Terraform](https://www.terraform.io/) is an open source tool that is ideal for
|
|
|
|
provisioning new infrastructure with images generated by Packer, and [Terraform
|
|
|
|
Enterprise](https://www.hashicorp.com/products/terraform/) is the best way to
|
|
|
|
perform automated Terraform runs.
|
2017-12-08 16:46:51 -05:00
|
|
|
|
|
|
|
## Create a Terraform Configuration and Workspace
|
|
|
|
|
2017-12-11 18:10:37 -05:00
|
|
|
The following is a sample Terraform configuration which provisions a new AWS
|
2020-03-18 18:46:47 -04:00
|
|
|
EC2 instance. The `aws_ami_id` is a variable which will be provided when
|
2017-12-11 18:10:37 -05:00
|
|
|
running `terraform plan` and `terraform apply`. This variable references the
|
|
|
|
latest AMI generated with the Packer build in CI/CD.
|
2017-12-08 13:31:00 -05:00
|
|
|
|
|
|
|
```hcl
|
|
|
|
variable "aws_ami_id" { }
|
|
|
|
|
|
|
|
provider "aws" {
|
|
|
|
region = "us-west-2"
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "aws_instance" "web" {
|
|
|
|
ami = "${var.aws_ami_id}"
|
|
|
|
instance_type = "t2.micro"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2017-12-11 18:10:37 -05:00
|
|
|
Terraform Enterprise should have a workspace with this terraform configuration
|
|
|
|
and a placeholder variable `aws_ami_id`.
|
2017-12-08 13:31:00 -05:00
|
|
|
|
2017-12-08 16:46:51 -05:00
|
|
|
## Include Terraform Enterprise in Your CI Builds
|
|
|
|
|
2017-12-11 18:10:37 -05:00
|
|
|
Follow these steps to create a new run from CI/CD after a Packer build is
|
|
|
|
complete and uploaded.
|
2017-12-08 13:31:00 -05:00
|
|
|
|
|
|
|
1. Add a new step to the CI/CD pipeline.
|
2017-12-11 18:10:37 -05:00
|
|
|
2. In the new step add a `curl` call to update the variables in the workspace
|
|
|
|
using the [update variables
|
2017-12-12 01:05:50 -05:00
|
|
|
API](https://www.terraform.io/docs/enterprise/api/variables.html#update-variables),
|
2017-12-11 18:10:37 -05:00
|
|
|
so that Terraform has a reference to the latest image. For the sample
|
|
|
|
configuration above, the `aws_ami_id` variable should be updated to the AMI
|
|
|
|
ID of the latest image.
|
|
|
|
3. In that same step, add another `curl` call to [create a new run via the
|
2017-12-12 01:05:50 -05:00
|
|
|
API](https://www.terraform.io/docs/enterprise/api/run.html#create-a-run).
|
2017-12-11 18:10:37 -05:00
|
|
|
A run performs a plan and apply on the last configuration version created,
|
|
|
|
using the variables set in the workspace. In the previous step we update the
|
|
|
|
variables, so the new run can be created using the previous configuration
|
|
|
|
version.
|