Guida introduttiva: Creare un profilo di Gestione traffico di Azure con Terraform
Questa guida introduttiva descrive come usare Terraform per creare un profilo Gestione traffico con endpoint esterni usando il metodo di routing delle prestazioni.
Terraform consente di definire, visualizzare in anteprima e distribuire l'infrastruttura cloud. Con Terraform è possibile creare file di configurazione usando la sintassi HCL. La sintassi HCL consente di specificare il provider di servizi cloud, ad esempio Azure, e gli elementi che costituiscono l'infrastruttura cloud. Dopo aver creato i file di configurazione, è necessario creare un piano di esecuzione che consenta di visualizzare in anteprima le modifiche apportate all'infrastruttura prima che vengano distribuite. Dopo aver verificato le modifiche, è possibile applicare il piano di esecuzione per distribuire l'infrastruttura.
In questo articolo vengono illustrate le operazioni seguenti:
- Creare un valore casuale per il nome del gruppo di risorse di Azure usando random_pet.
- Creare un gruppo di risorse di Azure usando azurerm_resource_group.
- Creare un valore casuale per il nome del profilo Gestione traffico di Azure usando random_string.
- Creare un valore casuale per il nome relativo della configurazione DNS del profilo Gestione traffico di Azure usando random_string.
- Creare un profilo di Gestione traffico di Azure usando azurerm_traffic_manager_profile.
- Creare due endpoint esterni Gestione traffico di Azure usando azurerm_traffic_manager_external_endpoint.
Nota
Il codice di esempio per questo articolo si trova nel repository GitHub di Azure Terraform. È possibile visualizzare il file di log contenente i risultati del test delle versioni correnti e precedenti di Terraform.
Vedere altri articoli e codice di esempio che illustrano come usare Terraform per gestire le risorse di Azure
Creare una directory in cui testare ed eseguire il codice Terraform di esempio e impostarla come directory corrente.
Creare un file denominato
providers.tf
e inserire il codice seguente:terraform { required_version = ">=1.0" required_providers { azurerm = { source = "hashicorp/azurerm" version = "~>3.0" } random = { source = "hashicorp/random" version = "~>3.0" } } } provider "azurerm" { features {} }
Creare un file denominato
main.tf
e inserire il codice seguente:resource "random_pet" "rg_name" { prefix = var.resource_group_name_prefix } resource "azurerm_resource_group" "rg" { name = random_pet.rg_name.id location = var.resource_group_location } resource "random_string" "azurerm_traffic_manager_profile_name" { length = 25 upper = false numeric = false special = false } resource "random_string" "azurerm_traffic_manager_profile_dns_config_relative_name" { length = 10 upper = false numeric = false special = false } resource "azurerm_traffic_manager_profile" "profile" { name = random_string.azurerm_traffic_manager_profile_name.result resource_group_name = azurerm_resource_group.rg.name traffic_routing_method = "Performance" dns_config { relative_name = random_string.azurerm_traffic_manager_profile_dns_config_relative_name.result ttl = 30 } monitor_config { protocol = "HTTPS" port = 443 path = "/" expected_status_code_ranges = ["200-202", "301-302"] } } resource "azurerm_traffic_manager_external_endpoint" "endpoint1" { profile_id = azurerm_traffic_manager_profile.profile.id name = "endpoint1" target = "www.contoso.com" endpoint_location = "eastus" weight = 50 } resource "azurerm_traffic_manager_external_endpoint" "endpoint2" { profile_id = azurerm_traffic_manager_profile.profile.id name = "endpoint2" target = "www.fabrikam.com" endpoint_location = "westus" weight = 50 }
Creare un file denominato
variables.tf
e inserire il codice seguente:variable "resource_group_location" { type = string description = "Location for all resources." default = "eastus" } variable "resource_group_name_prefix" { type = string description = "Prefix of the resource group name that's combined with a random ID so name is unique in your Azure subscription." default = "rg" }
Creare un file denominato
outputs.tf
e inserire il codice seguente:output "resource_group_name" { value = azurerm_resource_group.rg.name } output "azurerm_traffic_manager_profile_name" { value = azurerm_traffic_manager_profile.profile.name } output "azurerm_traffic_manager_profile_fqdn" { value = azurerm_traffic_manager_profile.profile.fqdn }
Per inizializzare la distribuzione di Terraform, eseguire terraform init. Questo comando scarica il provider di Azure necessario per gestire le risorse di Azure.
terraform init -upgrade
Punti principali:
- Il parametro
-upgrade
aggiorna i plug-in del provider necessari alla versione più recente conforme ai vincoli di versione della configurazione.
Eseguire terraform plan per creare un piano di esecuzione.
terraform plan -out main.tfplan
Punti principali:
- Il comando
terraform plan
consente di creare un piano di esecuzione, ma non di eseguirlo. Determina invece le azioni necessarie per creare la configurazione specificata nei file di configurazione. Questo modello consente di verificare se il piano di esecuzione corrisponde alle aspettative prima di apportare modifiche alle risorse effettive. - Il parametro
-out
facoltativo consente di specificare un file di output per il piano. L'uso del parametro-out
garantisce che il piano esaminato sia esattamente quello che viene applicato.
Eseguire terraform apply per applicare il piano di esecuzione all'infrastruttura cloud.
terraform apply main.tfplan
Punti principali:
- Il comando
terraform apply
di esempio presuppone che in precedenza sia stato eseguitoterraform plan -out main.tfplan
. - Se è stato specificato un nome di file diverso per il parametro
-out
, usare lo stesso nome di file nella chiamata aterraform apply
. - Se non è stato usato il parametro
-out
, chiamareterraform apply
senza parametri.
Ottenere il nome del gruppo di risorse di Azure.
resource_group_name=$(terraform output -raw resource_group_name)
Ottenere il nome del profilo Gestione traffico.
traffic_manager_profile_name=$(terraform output -raw azurerm_traffic_manager_profile_name)
Eseguire az network traffic-manager profile show per visualizzare informazioni sul nuovo profilo di Gestione traffico.
az network traffic-manager profile show \ --resource-group $resource_group_name \ --name $traffic_manager_profile_name
Quando le risorse create tramite Terraform non sono più necessarie, eseguire i passaggi seguenti:
Eseguire il piano Terraform e specificare il flag
destroy
.terraform plan -destroy -out main.destroy.tfplan
Punti principali:
- Il comando
terraform plan
consente di creare un piano di esecuzione, ma non di eseguirlo. Determina invece le azioni necessarie per creare la configurazione specificata nei file di configurazione. Questo modello consente di verificare se il piano di esecuzione corrisponde alle aspettative prima di apportare modifiche alle risorse effettive. - Il parametro
-out
facoltativo consente di specificare un file di output per il piano. L'uso del parametro-out
garantisce che il piano esaminato sia esattamente quello che viene applicato.
- Il comando
Eseguire terraform apply per applicare il piano di esecuzione.
terraform apply main.destroy.tfplan
Risolvere i problemi comuni relativi all'uso di Terraform in Azure