/terraform-aks-appgw-acr-keyvault-loganalytics

Fully configured AKS cluster deployed through Terraform with Application Gateway, Azure Key Vault, Azure Container Registry, Pod Identity and Log Analytics

Primary LanguageHCLMIT LicenseMIT

Terraform - Azure Kubernetes Service deployment

Setting up an Azure Kubernetes Service (AKS) using terraform, is fairly easy. Setting up a full-fledged AKS cluster that can read images from Azure Container Registry (ACR), fetch secrets from Azure Key Vault using Pod Identity while all traffic is routed via an AKS managed Application Gateway is much harder.

This repository serves as a boilerplate for the scenario described above, and fully deploys and configures your Azure Kubernetes Service in the cloud using a single terraform deployment.

Architecture

Architecture Diagram AKS deployment

The architecture consists of the following components:

Public IP — Public IP addresses enable Azure resources to communicate to Internet and public-facing Azure services.

Application Gateway — Azure Application Gateway is a web traffic load balancer that enables you to manage traffic to your web applications.

Azure Kubernetes Service (AKS) — AKS is an Azure service that deploys a managed Kubernetes cluster.

Virtual Network — An Azure Virtual Network (VNet) is used to securely communicate between AKS and Application Gateway and control all outbound connections.

Virtual Network subnets — Application Gateway and AKS are deployed in their own subnets within the same virtual network.

External Data Sources — Microservices are typically stateless and write state to external data stores, such as CosmosDB.

Azure Key Vault — Azure Key Vault is a cloud service for securely storing and accessing secrets and certificates.

Pod Identity — Pod Identity enables Kubernetes applications to access cloud resources securely with Azure Active Directory.

Azure Active Directory — Azure Active Directory (Azure AD) is Microsoft's cloud-based identity and access management service. Pod Identity uses Azure AD to create and manage other Azure resources such as Azure Application Gateway and Azure Key Vault.

Azure Container Registry — Container Registry is used to store private Docker images, which are deployed to the cluster. AKS can authenticate with Container Registry using its Azure AD identity.

KEDA — KEDA is a Kubernetes-based Event Driven Autoscaler that (horizontally) scales a container by adding additional pods based on the number of events needing to be processed.

Input Variables

Name Description Default
app_name Application name (used as suffix in all resources)
location Azure region where to create resources West Europe
domain_name_label Unique domain name label for AKS Cluster
kubernetes_version Kubernetes version of the node pool 1.19.7
vm_size_node_pool VM Size of the node pool Standard_D2s_v3
node_pool_min_count VM minimum amount of nodes for the node pool 3
node_pool_max_count VM maximum amount of nodes for the node pool 5
helm_pod_identity_version Helm chart version of aad-pod-identity 4.1.1
helm_csi_secrets_version Helm chart version of secrets-store-csi-driver-provider-azure 0.0.18
helm_agic_version Helm chart version of ingress-azure-helm-package 1.4.0
helm_keda_version Helm chart version of keda helm package 2.3.2

Output variables

Name Description
aks_name Name of the AKS cluster
appgw_name Name of the Application Gateway used by AKS
appgw_fqdn Domain name of the cluster (e.g. label.westeurope.cloudapp.azure.com)
acr_name Name of the Azure Container Registry
keyvault_name Name of the Azure Key Vault
log_analytics_name Name of the Log Analytics workspace
vnet_name Name of the Virtual Network
rg_name Name of the Resource Group