Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
To make your applications more resilient to zone-related hardware failures, network disruptions, and natural disasters, it's important that design your Azure workloads for zone resiliency. When you distribute resources across multiple availability zones within a region, you reduce the risk of a single zone outage affecting critical services.
Although it's a best practice to address zone resiliency during the initial planning and deployment of workloads, it's common to want to convert existing non-resilient workloads to zone resilient configurations. In general, the processing of enabling zone resiliency for existing workloads is straightforward, and Azure continues to simplify the process. However, any change to your workload can introduce an amount of risk. Once you understand the risks that are involved, you'll then be able to assess and prioritize which workloads and services within those workloads are most vital to your business, then apply zone resiliency to the most impactful resources first.
This article outlines key considerations for enabling zone resiliency in your Azure workloads. It also helps you plan and implement a successful transition to a more resilient architecture.
Tip
If you're currently in the process of designing your workloads or plan to do a design review of your current workloads, it's important that you follow the recommendations for designing for redundancy in the Azure Well-Architected Framework (WAF). The WAF recommendations guide helps you design workload redundancy across multiple levels, with a focus on critical workflows. To support availability zone adoption, it also outlines strategies like multi-region deployments and deployment stamps.
What is zone resiliency?
Azure services can be made resilient to availability zone outages in two primary ways:
Zone-redundant services: Many Azure services support zone redundancy. These services automatically replicate data between availability zones, distribute incoming requests, and fail over to different zones during a zone failure. Each service supports these capabilities in a way that makes sense for that specific service. Some services are zone redundant by default, while other services might need you to configure zone redundancy.
Zonal services: Some Azure services are zonal, which means that they can be pinned to a specific availability zone. To achieve zone resiliency by using a zonal service, deploy separate instances of the service in multiple availability zones. You might also need to manage traffic distribution, replication of data, and failover between the instances.
Some services can be deployed in either a zone-redundant or zonal configuration. For most cases, it's best to deploy zone-redundant services when you can.
For more information, see Types of availability zone support.
Zone enablement procedure
Use the following steps to systematically review your Azure workloads, prioritize them for zone resiliency, and enable zone resiliency for each component.
Prerequisites
Before you begin, perform the following actions:
Identify each workload. A workload refers to a collection of application resources, data, and supporting infrastructure that function together to achieve defined business outcomes. For more information about workloads and how to define them, see Well-Architected Framework workloads.
Prioritize each workload's user and system flows. Understand the critical paths and dependencies of your workloads to determine which components to make zone resilient first. For more information about how to use critical flow analysis to prioritize workflows, see Prioritize workloads for zone resiliency.
Assign a criticality rating to each workload and flow. This rating helps you understand the impact of a potential outage on your business and guides your decisions about which workloads to prioritize for zone resiliency. Also consider the amount of acceptable downtime while you reconfigure the workloads.
You can use a taxonomy to classify your workloads based on their criticality. This approach helps you focus your efforts on the most important services.
Consider the following example taxonomy to classify your workloads.
Workload type Description Effect of disruption Mission-critical Critical flows and workloads that must be highly reliable, always available, resilient to failures, and operational Any disruption to essential functions immediately risks catastrophic business damage or introduces risks to human life. Business-critical Essential flows and workloads that operate important business functions Disruption risks some financial loss or brand damage. Business‑operational Contributes to efficiency of business operations, but out of direct line-of-service to customers Can tolerate some level of disruption. Administrative Internal production flows and workloads not aligned to business operations Can tolerate disruption. For more information about how to classify your workloads according to criticality rating, see Assign a criticality rating to each flow.
Verify that the regions where your Azure resources reside support availability zones. Consult the Azure regions list . If a region doesn't support availability zones, consider relocating your resources to a region that does. For more information, see Move Azure resources across resource groups, subscriptions, or regions.
Step 1: Prioritize Azure services for zone resilience
After you determine which workload flows are most critical to your business, you can focus on the Azure services that those flows depend on. Some Azure services are more critical to your applications than others. Prioritize these services to help ensure that your applications remain available and resilient if a zone failure occurs.
Use the following guidance to prioritize Azure service groups based on their criticality to your workloads. Consider your specific application architecture and business requirements when you determine the priority of services for zone resiliency.
Start with networking services. Workloads tend to share networking services, so an increase in the resiliency of these services can improve the resiliency of multiple workloads at once.
Many core networking services are zone redundant automatically, but you should focus on components like Azure ExpressRoute gateways, Azure VPN Gateway, Azure Application Gateway, Azure Load Balancer, and Azure Firewall.
Improve operational data storage resiliency. Operational data stores contain valuable data that multiple workloads often use, so improving the availability of those data stores can help many workloads.
For operational data storage resiliency, focus on services like Azure SQL Database, Azure SQL Managed Instance, Azure Storage, Azure Data Lake Storage, Azure Cosmos DB, Azure PostgreSQL Flexible Server, Azure MySQL Flexible Server, and Azure Cache for Redis.
Prioritize compute services. These services are often easy to replicate and distribute among zones because they're stateless.
Compute services include Azure Virtual Machines, Azure Virtual Machine Scale Sets, Azure Kubernetes Service (AKS), Azure App Service, App Service Environment, Azure Functions, Azure Service Fabric, and Azure Container Apps.
Review remaining business-critical resources that your critical flows use. These resources might not be as critical as the resources listed previously, but they still play a role in your application's functionality, and you should consider them for zone resiliency.
Review the rest of your business-operational resources. Make informed decisions about whether to make them zone resilient. This review includes services that might not directly relate to your critical workloads but still contribute to overall application performance and reliability.
Step 2: Assess zone configuration approaches
After you prioritize your workloads and Azure services, identify the approach required to enable availability zone support for each service, and understand what you need to do to configure zone resiliency.
Each Azure reliability service guide provides a section that describes how to enable zone resiliency for that service. This section helps you understand the effort required to make each service zone resilient so that you can plan your strategy accordingly. For more information about a specific service, see Azure reliability service guides.
Use the zone configuration table to quickly understand approaches for common Azure services.
Important
If your workload includes components deployed in a zonal (or single-zone) configuration, plan to make these components resilient to zone outages. A common approach is to deploy separate instances into another availability zone and switch between them if necessary.
Step 3: Test for latency
When you make workloads zone resilient, consider latency between availability zones. Occasionally, some legacy systems can't tolerate the small amount of extra latency that cross-zone traffic introduces, especially when you enable synchronous replication within the data tier. If you suspect that cross-zone latency might affect your workload, run tests before and after you enable zone resiliency.
Zone configuration approaches for Azure services
Each Azure service supports a specific type of availability zone support, which is based on the service's intended use and internal architecture. If you have a resource that isn't configured to use availability zones (or a nonzonal resource), you might want to reconfigure it with availability zone support. The reliability guide for that service provides guidance or links to availability zone configuration instructions.
This section provides an overview of the different types of zone configuration approaches and which approach each service supports.
Important
When you enable zone redundancy on a resource, that resource becomes automatically resilient to zone failures. When you use a zonal configuration to pin the resource to a specific availability zone, the resource isn't automatically zone redundant. You must make it resilient to a zone failure. For zonal services, this article reflects the complexity and cost of pinning to a zone. For more information about extra steps to achieve zone resiliency, see the service's reliability guide.
The zone configuration table lists the supported zone configuration approach for many Azure services and contains a link to each reliability guide for that service. The reliability guide provides information about how to configure nonzonal service resources to enable availability zone support.
The following table describes each zone configuration approach, including the level of effort and downtime required to enable availability zones.
| Approach | Description | Typical level of effort | Might require downtime |
|---|---|---|---|
| Always zone resilient | The service is zone resilient by default in regions that support availability zones . No action is required. | None | No |
| Enablement | Minimal configuration changes required, such as enabling zone redundancy in settings. The process doesn't affect availability, but consider effects on cost or performance. | Low | No |
| Modification | Likely requires some configuration changes, such as redeploying dependent resources or modifying network settings. | Medium | Yes |
| Redeployment | Significant changes required, such as redeploying entire resources, applications, or services, or migrating data to new services. | High | Yes |
Understand the cost of enabling availability zone support for a service. For many services, enabling availability zones doesn't add cost. But some services require a specific tier, a specific number of capacity units, or both. Other services charge different rates when you use availability zones. The table in the next section lists the typical cost impact for each service.
Note
The information in this article summarizes the typical approach to enable availability zone support and outlines the typical cost impact. But some factors might affect how it works for your specific solution. For example, some services are listed as always zone resilient, but this designation only applies in specific regions or for specific tiers of the service. Use these tables as a starting point, but review the other resources mentioned to understand the specific details.
Azure services by zone configuration approach
The following table summarizes the availability zone support for many Azure services and provides an approach, including cost impact, to enable availability zone support for each service.
| Service | Can be zone redundant | Can be zonal | Typical zone configuration approach | Typical cost impact |
|---|---|---|---|---|
| Azure AI Search | Always zone resilient | N/A | ||
| Azure API Management | Modification | Minimum tier required | ||
| Azure App Configuration | Always zone resilient | N/A | ||
| Azure App Service | Enablement | Minimum tier and instance count required | ||
| Azure App Service - App Service Environment | Enablement | Minimum instance count required | ||
| Azure Application Gateway | Always zone resilient | N/A | ||
| Azure Backup | Redeployment | Moderate cost increase | ||
| Azure Batch | Redeployment | No cost impact for same number of virtual machines (VMs) | ||
| Azure Blob Storage | Enablement | Moderate cost increase | ||
| Azure Cache for Redis - Enterprise | Redeployment | No cost impact | ||
| Azure Cache for Redis - Standard and Premium | Enablement | Minimum tier required | ||
| Azure Container Apps | Redeployment | Minimum replica count required | ||
| Azure Container Registry | Always zone resilient | N/A | ||
| Azure Cosmos DB for NoSQL | Modification | None if using autoscale or multi-region writes | ||
| Azure Data Factory | Always zone resilient | N/A | ||
| Azure Data Lake Storage | Enablement | Moderate cost increase | ||
| Azure Database for MySQL - Flexible Server | Redeployment | Requires primary and high availability (HA) instance | ||
| Azure Database for PostgreSQL - Flexible Server | Enablement | Requires primary and HA instance | ||
| Azure Disk Storage (managed disks) | Enablement | Moderate cost increase | ||
| Azure Event Hubs: all other tiers | Always zone resilient | N/A | ||
| Azure ExpressRoute | Modification | Depends on tier | ||
| Azure Files | Enablement | Moderate cost increase | ||
| Azure Firewall | Modification | No cost impact | ||
| Azure Functions | Redeployment | Minimum tier and instance count required | ||
| Azure Key Vault | Always zone resilient | N/A | ||
| Azure Kubernetes Service (AKS) | Redeployment | No cost impact | ||
| Azure Load Balancer | Modification | No cost impact | ||
| Azure Logic Apps - Consumption tier | Always zone resilient | N/A | ||
| Azure Logic Apps - Standard tier | Redeployment | Minimum tier and instance count required | ||
| Azure Managed Grafana | Redeploy | Moderate cost increase | ||
| Azure Queue Storage | Enablement | Moderate cost increase | ||
| Azure Service Bus | Always zone resilient | N/A | ||
| Azure Service Fabric | Redeployment | No cost impact for same number of VMs | ||
| Azure Site Recovery | Redeployment | No cost impact for Site Recovery, moderate cost increase for replica storage | ||
| Azure SQL Database: Business Critical tier | Enablement | No cost impact | ||
| Azure SQL Database: General Purpose tier | Enablement | Moderate cost increase | ||
| Azure SQL Database: Hyperscale tier | Redeployment | Minimum replica count required | ||
| Azure SQL Database: Premium tier | Enablement | No cost impact | ||
| Azure SQL Managed Instance | Enablement | Moderate cost increase | ||
| Azure Table Storage | Enablement | Moderate cost increase | ||
| Azure Virtual Machine Scale Sets | Redeployment | No cost impact for same number of VMs | ||
| Azure Virtual Machines | Redeployment | No cost impact for same number of VMs | ||
| Azure Virtual Network | Always zone resilient | N/A | ||
| Public IP address | Always zone resilient | N/A |