This is a sample that allows to create infrastructure in Azure cloud using IaC concept with tools such as Terraform and Azure DevOps.
On this project you will be able to create a PaS Azure Resource called App Service. This Azure resource will allow to you to deploy your web app, for this sample a .net web app.
Within this repo is a folder called Terraform and a file called appService.tf that contains the definition of the infrastructure that will be deployed on Azure. The file contains the definition for the following Azure resources:
- Resource Group
- App Service Plan
- App Service
Each resource has its required configurations such as the name and other parameters. If you use the terraform file from this repo you should change the name for your App Service resource since this should be a unique name within azure cloud.
- Install Azure CLI (if you want to test from your computer)
- Install Terraform (if you want to test from your computer)
- Create an Azure account.
- Create an Azure DevOps account.
You must create your Azure DevOps project that will contain the automated pipelines that deploy the infraestructure to the cloud.
- Open https://dev.azure.com
- Create a new organization
- Create the first project - name it
AzBootCamp2019
After you create your organization and project within Azure Devops you can proceed to create your automated pipeline.
- Create a new Release Pipeline
- Add an artifact, in this case your Github repo where your terraform code is hosted. You should add a new connection to your github in services management.
- Add a stage, e.g.: Dev or Prod. This stage should be an empty job.
For this sample you should use an agent that runs with Ubuntu OS since the scripts are written in bash.
These pipeline variables will be used in order to parametrize names for some resources and avoid the hardcoding withing the scripts. These variables will be used to create the Azure resources that will store the Terraform Backend. The variable "TerraformStorageAccount" refers to the name that you will set to the storage account in Azure that will stores the Terraform Backend, this variable should be different for any implementation since this should be a unique name within Azure Cloud.
By default, Terraform stores state locally in a file named terraform.tfstate. When working with Terraform in a team, use of a local file makes Terraform usage complicated. With remote state, Terraform writes the state data to a remote data store. For this sample we will use a Terraform CLI task that allows to create an Azure storage account and storage container to store Terraform state if this not exists yet. For more information on Terraform remote state click here
When running Terraform in automation, the focus is usually on the core plan/apply cycle. The main Terraform workflow is the following:
i. Initialize the Terraform working directory.
ii. Produce a plan for changing resources to match the current configuration.
iii. Apply the changes described by the plan.
The following tasks will allow you to implement the terraform cycle.
First you should install the extension in order to use the terraform task, select the extension created by Charles Zipp.
Once the extension is installed in your Azure DevOps you can add the task for Terraform Install, this task will guarantee that the agent that runs the command has Terraform installed.
Add Terraform CLI task to perform the Init Stage, you should select the command Init and for the Configuration directory you should point to the artifact configured before (repo and folder that contains the terraform files).
Configure the Azure Resource Manager section in order to set the Terraform Backend that will be located in azure, we should use the Pipeline variables configured previously.
This task runs terraform init command. The terraform init command looks through all of the *.tf files in the current working directory and automatically downloads any of the providers required for them. In this example, it will download Azure provider as we are going to deploy Azure resources. For more information about terraform init command click here.
Add Terraform CLI task like the init task, but for this one you should select the command Plan. You should set the Configuration Directory like the previous task. Also set the "Environment Azure Subscription" that should point to your Azure service connection configured before, you should authorize the connection if necessary.
The terraform plan command is used to create an executi]on plan. Terraform determines what actions are necessary to achieve the desired state specified in the configuration files. This is a dry run and shows which actions will be made. For more information about terraform plan command click here.
Add Terraform CLI task like previous tasks, but for this one you should select the command Apply. You should set the Configuration Directory like the previous task. Also set the "Environment Azure Subscription" that should point to your Azure service connection configured before.
This task will run the terraform apply command to deploy the resources to Azure Cloud.
Once the pipeline configuration is completed set a Name on it and save changes.
The Pipeline is now available to be selected and Create a Release, this action will start the execution of the pipeline and its tasks.
When the execution of the pipeline is finished you will be able the see the new infraestructure created in Azure.
Within the RG for the App Service you will see the new infrastructure.
Now a .net web app can be deployed to the new App Service.