diff --git a/quickstart/101-aks-extended-zones/README.MD b/quickstart/101-aks-extended-zones/README.MD new file mode 100644 index 000000000..c88c9d72c --- /dev/null +++ b/quickstart/101-aks-extended-zones/README.MD @@ -0,0 +1,23 @@ +# Azure Kubernetes Service (AKS) cluster in an Azure Extended Zone + +This template deploys an Azure Kubernetes Service (AKS) cluster in an Azure Extended Zones. + +## Terraform resource types + +- [random_pet](https://registry.terraform.io/providers/hashicorp/random/latest/docs/resources/pet) +- [azurerm_resource_group](https://registry.terraform.io/providers/hashicorp/azurerm/latest/docs/resources/resource_group) +- [azurerm_virtual_network](https://registry.terraform.io/providers/hashicorp/azurerm/latest/docs/resources/virtual_network) +- [azurerm_kubernetes_cluster](https://registry.terraform.io/providers/hashicorp/azurerm/latest/docs/resources/kubernetes_cluster) + +## Variables + +| Name | Description | Default value | +|-|-|-| +| `resource_group_name_prefix` | Prefix of the resource group name that's combined with a random ID so name is unique in your Azure subscription. | rg | +| `resource_group_location` | Location of the resource group. | Central US | +| `virtual_network_name` | Name of the virtual network resource. | example-vnet | +| `aks_node_count` | Number of nodes in the AKS cluster. | 3 | +| `aks_node_vm_size` | Size of the VMs in the AKS cluster. | Standard_D2_v2 | +| `admin_username` | The admin username for the Windows node pool. | azureuser | +| `admin_password` | The admin password for the Windows node pool. | Passw0rd1234Us! | +| `aks_extended_zone` | AKS extended zone. | Los Angeles | diff --git a/quickstart/101-aks-extended-zones/main.tf b/quickstart/101-aks-extended-zones/main.tf new file mode 100644 index 000000000..3a2a8900a --- /dev/null +++ b/quickstart/101-aks-extended-zones/main.tf @@ -0,0 +1,62 @@ +resource "random_pet" "rg_name" { + prefix = var.resource_group_name_prefix +} + +resource "azurerm_resource_group" "rg" { + location = var.resource_group_location + name = random_pet.rg_name.id +} + +resource "random_pet" "azurerm_kubernetes_cluster_name" { + prefix = "cluster" +} + +resource "random_pet" "azurerm_kubernetes_cluster_dns_prefix" { + prefix = "dns" +} + +resource "azurerm_virtual_network" "vnet" { + name = var.virtual_network_name + address_space = ["192.168.0.0/16"] + location = azurerm_resource_group.rg.location + resource_group_name = azurerm_resource_group.rg.name + + subnet { + name = "subnet1" + address_prefix = "192.168.1.0/24" + } +} + +resource "azurerm_kubernetes_cluster" "aks" { + name = random_pet.azurerm_kubernetes_cluster_name.id + location = azurerm_resource_group.rg.location + resource_group_name = azurerm_resource_group.rg.name + dns_prefix = random_pet.azurerm_kubernetes_cluster_dns_prefix.id + + identity { + type = "SystemAssigned" + } + + default_node_pool { + name = "agentpool" + vm_size = var.aks_node_vm_size + node_count = var.aks_node_count + vnet_subnet_id = element(tolist(azurerm_virtual_network.vnet.subnet), 0).id + } + + windows_profile { + admin_username = var.admin_username + admin_password = var.admin_password + } + + network_profile { + network_plugin = "azure" + load_balancer_sku = "standard" + } + + edge_zone = var.aks_extended_zone + + timeouts { + create = "6h" + } +} \ No newline at end of file diff --git a/quickstart/101-aks-extended-zones/outputs.tf b/quickstart/101-aks-extended-zones/outputs.tf new file mode 100644 index 000000000..c2cce80fb --- /dev/null +++ b/quickstart/101-aks-extended-zones/outputs.tf @@ -0,0 +1,11 @@ +output "resource_group_name" { + value = azurerm_resource_group.rg.name +} + +output "aks_cluster_name" { + value = azurerm_kubernetes_cluster.aks.name +} + +output "aks_extended_zone" { + value = azurerm_kubernetes_cluster.aks.edge_zone +} \ No newline at end of file diff --git a/quickstart/101-aks-extended-zones/providers.tf b/quickstart/101-aks-extended-zones/providers.tf new file mode 100644 index 000000000..7261b1fb4 --- /dev/null +++ b/quickstart/101-aks-extended-zones/providers.tf @@ -0,0 +1,16 @@ +terraform { + required_providers { + azurerm = { + source = "hashicorp/azurerm" + version = "~>3.0" + } + random = { + source = "hashicorp/random" + version = "~>3.0" + } + } +} + +provider "azurerm" { + features {} +} \ No newline at end of file diff --git a/quickstart/101-aks-extended-zones/variables.tf b/quickstart/101-aks-extended-zones/variables.tf new file mode 100644 index 000000000..d66cf8c1d --- /dev/null +++ b/quickstart/101-aks-extended-zones/variables.tf @@ -0,0 +1,47 @@ +variable "resource_group_name_prefix" { + type = string + default = "rg" + description = "Prefix of the resource group name that's combined with a random ID so name is unique in your Azure subscription." +} + +variable "resource_group_location" { + type = string + default = "West US" + description = "Location of the resource group." +} + +variable "virtual_network_name" { + type = string + description = "Virtual network names" + default = "example-vnet" +} + +variable "aks_node_count" { + type = number + description = "AKS node count" + default = 3 +} + +variable "aks_node_vm_size" { + type = string + description = "AKS node VM size" + default = "Standard_D2_v2" +} + +variable "admin_username" { + type = string + description = "The admin username for the Windows node pool." + default = "azureuser" +} + +variable "admin_password" { + type = string + description = "The admin password for the Windows node pool." + default = "Passw0rd1234Us!" +} + +variable "aks_extended_zone" { + type = string + description = "AKS extended zone" + default = "Los Angeles" +} \ No newline at end of file