1 - Multi-Region Hub and Spoke Virtual Network with Azure Firewall
A full Platform landing zone deployment with hub and spoke Virtual Network connectivity using Azure Firewall in multiple regions.
- Example Platform landing zone configuration file: full-multi-region/hub-and-spoke-vnet.tfvars
- Estimated Costs - Approximate monthly infrastructure costs
- Resources - What gets deployed in this scenario
- Configuration - How DNS, routing, and policies are configured
| Resource | Estimated Monthly Cost (USD) |
|---|---|
| Azure Firewall (Premium) x2 | 2,555.00 |
| Firewall Policy (Standard) x2 | 200.00 |
| VPN Gateway (VpnGw2AZ) x2 | 788.40 |
| ExpressRoute GW (ErGw2AZ) x2 | 922.72 |
| Azure Bastion (Standard) x2 | 423.40 |
| DDoS Protection Plan | 2,944.00 |
| Private DNS Resolver x2 | 360.00 |
| Private DNS Zones (x110) | 55.00 |
| Public IP Addresses (x8) | 29.20 |
| Total | 8,277.72 |
NoteEstimated fixed infrastructure costs based on Azure Retail Prices for the westus region in USD as of 2026-04-02. Consumption-based costs (data processing, log ingestion, DNS queries, etc.) are not included and will vary based on usage. DDoS Protection Plan pricing is sourced from the Azure DDoS Protection pricing page. You can generate your own estimates for any region and currency using the Get-ScenarioCostEstimates.ps1 script.
The following resources are deployed by default in this scenario:
- Management Groups
- Policy Definitions
- Policy Set Definitions
- Policy Assignments
- Policy Assignment Role Assignments
- Log Analytics Workspace
- Log Analytics Data Collection Rules for AMA
- User Assigned Managed Identity for AMA
- Automation Account
TipIdentity and Security subscriptions are recommended but optional. If you do not yet have dedicated subscriptions for identity and security workloads, you can comment out or remove the identity and security subscription placement blocks in the configuration file and add them later.
- Connectivity subscription - placed under the
connectivitymanagement group - Management subscription - placed under the
managementmanagement group - Identity subscription - placed under the
identitymanagement group (recommended) - Security subscription - placed under the
securitymanagement group (recommended)
- DDOS Protection Plan
- Hub virtual networks in each region
- Hub virtual network peering
- Subnets for Firewall, Gateway, Bastion, and Private DNS Resolver in each region
- Azure Route table for Firewall per region
- Azure Route table for other subnets and spokes per region
- Azure Firewall per region
- Azure Firewall public IP per region
- Azure Firewall policy per region
- Azure Bastion per region
- Azure Bastion public IP per region
- Azure Private DNS Resolver per region
- Azure non-regional Private Link Private DNS zones in primary region
- Azure regional Private Link Private DNS zones per region
- Azure Virtual Machine auto-registration Private DNS zone per region
- Azure Private Link DNS zone virtual network links per region
- Azure ExpressRoute Virtual Network Gateway per region
- Azure VPN Virtual Network Gateway per region
The following relevant configuration is applied:
Private DNS is configured ready for using Private Link and Virtual Machine Auto-registration. Spoke Virtual Networks should use the Azure Firewall IP Address in the same region as their DNS configuration.
- Azure Firewall is configured as DNS proxy
- Azure Firewall forwards DNS traffic to the Private DNS resolver
- Azure Private DNS Resolver has an inbound endpoint from the hub network
- Azure Private Link DNS zones are linked to all the hub Virtual Networks
Route tables are pre-configured for spoke virtual networks in each region. Assign the user subnet route table to any subnets created in spokes.
- Azure Firewall in relevant region as next hop in Route Table
