title | description |
---|---|
Build a Static Website on Azure with Terraform |
Learn to automate Static Website creation on Azure with Terraform |
- End Goal: Build a Terraform Local Module
- Create a Terraform module
- Use local Terraform modules in your configuration
- Configure modules with variables
- Use module outputs
- We are going to write a local re-usable module for the following usecase.
- Usecase: Hosting a static website using Azure Storage Account
- Create a Azure Storage Account
- Enable
Static webstite
option - Upload Static Content and test
- For steps, 1 and 2 we are going to create a re-usable module in Terraform
- How are we going to do this?
- We are going to do this in 3 sections
- Section-1 - Full Manual: Create Static Website on Azure Storage Account using Azure Portal Management Console and host static content and test
- Section-2 - Terraform Resources: Automate section-1 using Terraform Resources
- Section-3 - Terraform Modules: Create a re-usable module for hosting static website by referencing section-2 terraform configuration files.
- Login to Azure Portal Console
- Go to Storage Accounts -> Create
- Resource Group: myrg-sw-1
- Storage account name: staticwebsitek123 (Should be unique across Azure)
- Region: East US
- Performance: Standard
- Redundancy: LRS
- Rest all leave to defaults
- Click on Review + Create
- Click on Create
- Goto Storage Account -> staticwebsitek123 -> Data Management -> Static Website
- Click on Enabled
- Index document name: index.html
- Error document path: error.html
- Goto Storage Account -> staticwebsitek123 -> Data Storage -> Containers -> $web
- Upload Static files from
static-content
folder
- index.html
- error.html
- Goto Storage Account -> staticwebsitek123 -> Data Management -> Static Website
- Get the endpoint name
Primary endpoint
# Primary Endpoint
https://staticwebsitek123.z13.web.core.windows.net/
- We have used multiple manual steps to host a static website on Azure Storage Account
- Now all the above manual steps automate using Terraform in next step
- We are going to host a static website on Azure Storage Account using general terraform configuration files
- Below will be the naming convention for Terraform Configs
- versions.tf
- main.tf
- variables.tf
- outputs.tf
- terraform.tfvars
# Terraform Block
terraform {
required_version = ">= 1.0.0"
required_providers {
azurerm = {
source = "hashicorp/azurerm"
version = ">= 2.0"
}
random = {
source = "hashicorp/random"
version = ">= 3.0"
}
null = {
source = "hashicorp/null"
version = ">= 3.0"
}
}
}
# Input variable definitions
variable "location" {
description = "The Azure Region in which all resources groups should be created."
type = string
}
variable "resource_group_name" {
description = "The name of the resource group"
type = string
}
variable "storage_account_name" {
description = "The name of the storage account"
type = string
}
variable "storage_account_tier" {
description = "Storage Account Tier"
type = string
}
variable "storage_account_replication_type" {
description = "Storage Account Replication Type"
type = string
}
variable "storage_account_kind" {
description = "Storage Account Kind"
type = string
}
variable "static_website_index_document" {
description = "static website index document"
type = string
}
variable "static_website_error_404_document" {
description = "static website error 404 document"
type = string
}
variable "static_website_source_folder" {
description = "static website source folder"
type = string
}
# Provider Block
provider "azurerm" {
features {}
}
# Random String Resource
resource "random_string" "myrandom" {
length = 6
upper = false
special = false
number = false
}
# Create Resource Group
resource "azurerm_resource_group" "resource_group" {
name = var.resource_group_name
location = var.location
}
# Create Azure Storage account
resource "azurerm_storage_account" "storage_account" {
name = "${var.storage_account_name}${random_string.myrandom.id}"
resource_group_name = azurerm_resource_group.resource_group.name
location = var.location
account_tier = var.storage_account_tier
account_replication_type = var.storage_account_replication_type
account_kind = var.storage_account_kind
static_website {
index_document = var.static_website_index_document
error_404_document = var.static_website_error_404_document
}
}
location = "eastus"
resource_group_name = "myrg1"
storage_account_name = "staticwebsite"
storage_account_tier = "Standard"
storage_account_replication_type = "LRS"
storage_account_kind = "StorageV2"
static_website_index_document = "index.html"
static_website_error_404_document = "error.html"
static_website_source_folder = "../static-content"
# Output variable definitions
output "resource_group_id" {
description = "resource group id"
value = azurerm_resource_group.resource_group.id
}
output "resource_group_name" {
description = "The name of the resource group"
value = azurerm_resource_group.resource_group.name
}
output "resource_group_location" {
description = "resource group location"
value = azurerm_resource_group.resource_group.location
}
output "storage_account_id" {
description = "storage account id"
value = azurerm_storage_account.storage_account.id
}
output "storage_account_name" {
description = "storage account name"
value = azurerm_storage_account.storage_account.name
}
# Terraform Initialize
terraform init
# Terraform Validate
terraform validate
# Terraform Format
terraform fmt
# Terraform Plan
terraform plan
# Terraform Apply
terraform apply -auto-approve
# Upload Static Content
1. Go to Storage Accounts -> staticwebsitexxxxxx -> Containers -> $web
2. Upload files from folder "static-content"
# Verify
1. Azure Storage Account created
2. Static Website Setting enabled
3. Verify the Static Content Upload Successful
4. Access Static Website: Goto Storage Account -> staticwebsitek123 -> Data Management -> Static Website
5. Get the endpoint name `Primary endpoint`
https://staticwebsitek123.z13.web.core.windows.net/
# Terraform Destroy
terraform destroy -auto-approve
# Delete Terraform files
rm -rf .terraform*
rm -rf terraform.tfstate*
- Using above terraform configurations we have hosted a static website in Azure Storage Account in seconds.
- In next step, we will convert these terraform configuration files to a Module which will be re-usable just by calling it.