Anteckning
Åtkomst till den här sidan kräver auktorisering. Du kan prova att logga in eller ändra kataloger.
Åtkomst till den här sidan kräver auktorisering. Du kan prova att ändra kataloger.
Gäller för: ✔️ Virtuella Windows-datorer
Den här artikeln visar hur du skapar ett kluster för virtuella Windows-datorer (som innehåller tre instanser av virtuella Windows-datorer) i Azure med Terraform.
- Skapa ett slumpmässigt värde för Azure-resursgruppens namn med hjälp av random_pet.
- Skapa en Azure-resursgrupp med hjälp av azurerm_resource_group.
- Skapa ett slumpmässigt värde för värdnamnet för den virtuella Windows-datorn random_string.
- Skapa ett slumpmässigt lösenord för de virtuella Windows-datorerna med hjälp av random_password.
- Skapa en virtuell Windows-dator med hjälp av beräkningsmodulen.
- Skapa ett virtuellt nätverk tillsammans med undernätet med hjälp av nätverksmodulen.
Förutsättningar
Implementera Terraform-koden
Kommentar
Exempelkoden för den här artikeln finns på Azure Terraform GitHub-lagringsplatsen. Du kan visa loggfilen som innehåller testresultaten från aktuella och tidigare versioner av Terraform.
Se fler artiklar och exempelkod som visar hur du använder Terraform för att hantera Azure-resurser
Skapa en katalog där du kan testa Terraform-exempelkoden och göra den till den aktuella katalogen.
Skapa en fil med namnet
providers.tfoch infoga följande kod:terraform { required_version = ">=1.0" required_providers { azurerm = { source = "hashicorp/azurerm" version = "~>3.0" } random = { source = "hashicorp/random" version = "~>3.0" } } } provider "azurerm" { features {} }Skapa en fil med namnet
main.tfoch infoga följande kod: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" "windows_server_vm_hostname" { length = 8 lower = true upper = false special = false } resource "random_pet" "windows_server_public_ip_dns" { prefix = "dns" } resource "random_password" "password" { length = 16 special = true lower = true upper = true numeric = true } # The following module is a Terraform Verified Module. # For more information about Verified Modules, see # https://github.com/azure/terraform-azure-modules/ module "windows_server" { count = 3 # Define 3 Windows Server VMs source = "Azure/compute/azurerm" resource_group_name = azurerm_resource_group.rg.name vnet_subnet_id = module.network.vnet_subnets[0] is_windows_image = true vm_hostname = "vm-${random_string.windows_server_vm_hostname.result}-${count.index}" delete_os_disk_on_termination = true admin_password = random_password.password.result vm_os_simple = "WindowsServer" public_ip_dns = ["${random_pet.windows_server_public_ip_dns.id}-${count.index}"] } # The following module is a Terraform Verified Module. # For more information about Verified Modules, see # https://github.com/azure/terraform-azure-modules/ module "network" { source = "Azure/network/azurerm" resource_group_name = azurerm_resource_group.rg.name version = "5.2.0" subnet_prefixes = ["10.0.1.0/24"] subnet_names = ["subnet1"] use_for_each = true }Skapa en fil med namnet
variables.tfoch infoga följande kod:variable "resource_group_location" { type = string default = "eastus" description = "Location for all resources." } variable "resource_group_name_prefix" { type = string default = "rg" description = "Prefix of the resource group name that's combined with a random value so name is unique in your Azure subscription." }Skapa en fil med namnet
outputs.tfoch infoga följande kod:output "resource_group_name" { value = azurerm_resource_group.rg.name } output "windows_vm_public_names" { value = module.windows_server[*].public_ip_dns_name } output "vm_public_ip_addresses" { value = module.windows_server[*].public_ip_address } output "vm_private_ip_addresses" { value = module.windows_server[*].network_interface_private_ip } output "vm_hostnames" { value = module.windows_server[*].vm_names }
Initiera Terraform
Kör terraform init för att initiera Terraform-distributionen. Det här kommandot laddar ned den Azure-provider som krävs för att hantera dina Azure-resurser.
terraform init -upgrade
Viktiga punkter:
- Parametern
-upgradeuppgraderar nödvändiga provider-plugin-program till den senaste versionen som uppfyller konfigurationens versionsbegränsningar.
Skapa en Terraform-körningsplan
Kör terraform plan för att skapa en körningsplan.
terraform plan -out main.tfplan
Viktiga punkter:
- Kommandot
terraform planskapar en körningsplan, men kör den inte. I stället avgör den vilka åtgärder som krävs för att skapa den konfiguration som anges i konfigurationsfilerna. Med det här mönstret kan du kontrollera om genomförandeplanen matchar dina förväntningar innan du gör några ändringar i de verkliga resurserna. - Med den valfria
-outparametern kan du ange en utdatafil för planen. Med hjälp av parametern-outser du till att planen du granskade är exakt vad som tillämpas.
Tillämpa en Terraform-körningsplan
Kör terraform apply för att utföra körningsplanen på din molninfrastruktur.
terraform apply main.tfplan
Viktiga punkter:
-
terraform applyExempelkommandot förutsätter att du tidigare kördeterraform plan -out main.tfplan. - Om du har angett ett annat filnamn för parametern
-outanvänder du samma filnamn i anropet tillterraform apply. - Om du inte använde parametern
-outanroparterraform applydu utan några parametrar.
Kostnadsinformation visas inte under processen för att skapa virtuella datorer för Terraform som för Azure-portalen. Mer information om hur kostnaden fungerar för virtuella datorer finns på sidan Översikt över kostnadsoptimering.
Verifiera resultatet
Hämta namnet på Azure-resursgruppen.
resource_group_name=$(terraform output -raw resource_group_name)Kör az vm list med en JMESPath-fråga för att visa namnen på de virtuella datorer som skapats i resursgruppen.
az vm list \ --resource-group $resource_group_name \ --query "[].{\"VM Name\":name}" -o table
Rensa resurser
Gör följande när du inte längre behöver de resurser som skapats via Terraform:
Kör terraform plan och ange
destroyflagga.terraform plan -destroy -out main.destroy.tfplanViktiga punkter:
- Kommandot
terraform planskapar en körningsplan, men kör den inte. I stället avgör den vilka åtgärder som krävs för att skapa den konfiguration som anges i konfigurationsfilerna. Med det här mönstret kan du kontrollera om utförandeplanen matchar dina förväntningar innan du gör några ändringar i verkliga resurser. - Med den valfria
-outparametern kan du ange en utdatafil för planen. Med hjälp av parametern-outser du till att planen du granskade är exakt vad som tillämpas.
- Kommandot
Kör terraform apply för att tillämpa exekveringsplanen.
terraform apply main.destroy.tfplan
Felsöka Terraform i Azure
Felsöka vanliga problem när du använder Terraform i Azure