Designing Your Network Infrastructure For Disaster Recovery
Authors: Nader Benmessaoud (Microsoft), Prateek Sharma (Microsoft)
Publication Date: June, 2015
Summary:This whitepaper is directed to IT professionals who are responsible for architecting, implementing, and supporting business continuity and disaster recovery (BCDR) infrastructure, and who want to leverage MicrosoftAzureSiteRecovery (ASR) to support and enhance their BCDR services. This paper discusses practical considerations forSystemCenter VirtualMachineManager server deployment, the pros and cons of stretched subnets vs. subnet failover, and how to structure disaster recovery to virtual sites in MicrosoftAzure.
© 2015 Microsoft Corporation. All rights reserved. This document is provided "as-is." Information and views expressed in this document, including URL and other Internet Web site references, may change without notice. You bear the risk of using it.
Some examples are for illustration only and are fictitious. No real association is intended or inferred.
This document does not provide you with any legal rights to any intellectual property in any Microsoft product. You may copy and use this document for your internal, reference purposes. You may modify this document for your internal, reference purposes.
Some information relates to pre-released product which may be substantially modified before it’s commercially released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Contents
About this whitepaper
Intended audience
Introduction
Designing System Center VMM deployment for Azure Site Recovery
Standalone deployment
Cluster deployment
VMM on a VM using Hyper-V Replica
Designing the network address space in a disaster recovery environment
Option 1: Retain IP addresses
Stretched Subnet
Subnet Failover
Subnet Failover – Enterprise Grade DR
On-Premises Subnet Failover – DR to Azure
Option 2: changing IP addresses
Changing the IP addresses – Enterprise Grade DR
Changing the IP addresses – DR to Azure
Resources
Revision History
#Pre-publication checklist; delete this section before publication
About this whitepaper
Azure Site Recovery[1] (ASR) is a Microsoft Azure service that orchestrates the protection and recovery of your virtualized applications for business continuity disaster recovery (BCDR) purposes. This document is intended to guide the reader through the process of designing the networks, focusing on architecting IP ranges and subnets on the disaster recovery site, when replicating virtual machines (VMs) using ASR.
Furthermore, this whitepaper demonstrates how ASR enables architecting and implementing a multisite virtual datacenter to support BCDR services at time of test or disaster.
Intended audience
This whitepaper is directed at IT professionals who are part of the virtualization team responsible for architecting, implementing, and supporting BCDR Infrastructure, and who want to leverage their virtual infrastructure to support and enhance their BCDR services. A typical virtualization team will contain members with skills in the following disciplines:
- Networking
- Server virtualization
- Operating system administration (Windows, Linux)
- ASR users, ASR evaluators, and IT decision makers.
Introduction
In a world where everyone expects 24/7 connectivity, it is more important than ever to keep your infrastructure and applications up and running. The purpose of Business Continuity and Disaster Recovery (BCDR) is to restore failed components so the organization can quickly resume normal operations. Developing disaster recovery strategies to deal with unlikely, devastating events is very challenging. This is due to the inherent difficulty of predicting the future, particularly as it relates to improbable events, and the high cost to provide adequate measures of protection against far-reaching catastrophes.
Crucial for BCDR planning, Recovery Time Objective (RTO) and Recovery Point Objective (RPO) must be defined as part of a disaster recovery plan. When a disaster strikes the customer’s data center, using Azure Site Recovery, customers can quickly (low RTO) bring online their replicated virtual machines located in either the secondary data center or Microsoft Azure with minimum data loss (low RPO).
Failover is made possible by ASR which initially copies designated virtual machines from the primary data center to the secondary data center or to Azure (depending on the scenario), and then periodically refreshes the replicas. During infrastructure planning, network design should be considered as potential bottleneck that can prevent you from meeting company RTO and RPO objectives.
When administrators are planning to deploy a disaster recovery solution, one of the key questions in their minds is how the virtual machine would be reachable after the failover is completed. Using Network Mapping in ASR, the administrator can choose which network the virtual machine would be attached to after failover. For more information about Network Mapping, see Site Recovery network mapping[2].
While designing the network for the recovery site, the administrator has two choices:
- Use a different IP address range for the network at recovery site. In this scenario the virtual machine after failover will get a new IP address and the administrator would have to do a DNS update. Read more about how to do the DNS update here
- Use same IP address range for the network at the recovery site. In certain scenarios administrators prefer to retain the IP addresses that they have on the primary site even after the failover. In a normal scenario an administrator would have to update the routes to indicate the new location of the IP addresses. But in the scenario where a stretched VLAN is deployed between the primary and the recovery sites, retaining the IP addresses for the virtual machines becomes an attractive option. Keeping the same IP addresses simplifies the recovery process by taking away any network related post-failover steps.
This document discusses two key technical considerations for designing your network address space for disaster recovery:
- Designing the fabric manager (System Center Virtual Machine Manager) deployment topology to protect workloads through Azure Site Recovery (ASR).
- IP Address Management in a disaster recovery environment.
Designing System Center VMM deployment for Azure Site Recovery
Business requirements dictate topology decisions. Based on these business requirements an organization might choose to have multiple data centers managed by a single management head, or multiple management heads managing different data centers. This section describes how an organization designs a System Center Virtual Machine Manager (SCVMM) deployment topology to protect workloads with ASR.
Azure Site Recovery contributes to your business continuity and disaster recovery (BCDR) strategy by orchestrating replication, failover, and recovery of virtual machines in a number of deployment scenarios. Based on the design principle of simplicity, ASR is modeled in a manner to allow administrators to build a disaster recovery solution on top of their existing data center topologies. ASR thus enables organizations to choose a topology that best satisfies their business needs.
For a full list of deployment scenarios see Azure Site Recovery overview.
Customers can protect workloads on a VMM server at the primary site with a VMM Server managing the secondary site.In the event of a disaster, all the workloads will seamlessly failover from the primary site to the secondary site that is being managed by the secondary VMM server. However, some organizations might want to use a single VMM server to manage all of their data centers in order to avoid management overhead. For a customer with this topology it is imperative to be able to recover the VMM server before the workloads can be recovered. As a result, a customer must cautiously design their VMM topologies in order to make their workloads “disaster proof.”
If you only have a single VMM server in your infrastructure you can deploy Azure Site Recovery to replicate virtual machines in VMM clouds to Azure, or you can replicate between clouds on a single VMM server. For recovery you'll need to manually fail over the VMM server from outside the Azure Site Recovery console using Hyper-V Replica in the Hyper-V Manager console.
It is recommended to deploy the VMM Server in one of the following topologies to be able to recover the workloads with the best possible RTO (Recovery Time Objective) and RPO (Recovery Point Objective).
Standalone deployment
In this topology, you will deploy a standalone VMM server on a virtual machine in the primary site, and then replicate this virtual machine to a secondary site with Azure Site Recovery and Hyper-VReplica. In some instances, installing the VMM sever and its supporting SQLServer on the same virtual machine can reduce downtime, because only one VM has to be instantiated. When the VMM service is using a remote SQLServer you'll need to recover the SQLServer instance before recovering the VMM server.
The steps to deploy a single VMM on a VM with Hyper-V Replica enabled are:
- Set up the VMM on a VM with SQL Server installed.
- Add the hosts to be managed to clouds on this VMM server.
- Log in to the Azure portal and then configure clouds for protection.
- Enable replication for all the VMs that need to be protected by the VMM server.
- Go to the Hyper-V Manager console, choose Hyper-V Replica, and then enable replication on the VMM VM. Ensure that the VMM VM is not added to the clouds that are protected by ASR service so that the Hyper-V Replication settings are not overridden by ASR.
In the event of a disaster, workloads can be recovered using the following steps:
- Failover the replica VMM VM to the recovery site, using Hyper-V Manager.
- After the VMM VM has been recovered, the user can login to the Hyper-V Recovery Manager from the secondary site.
- After the unplanned failover is complete, the user can access all the resources at the primary site.
This topology will require the user to manually failover their VMM VM to the secondary site before they can failover their workloads.
Figure 1
Cluster deployment
Deploying a highly available VMM server is a method of making the VMM service itself cluster aware. This is useful if critical workloads are being managed by VMM because it ensures workload availability and protects against a VMM server failure. It is extremely important to have the VMM server available at all times. Making the service cluster-aware helps to protect the VMM server against hardware failover of the host that the VMM Server is running on, as well as protecting againstproblems that may occur in the VMon which VMM is running. Deploying a highly available VMM server requires the VMM server to be present on a WindowsServer Failover Cluster. For more information about how to deploy a highly available VMM server, see the System Center blog post available here[3].
When protecting workloads using ASR, the VMM server should be deployed over a stretched cluster across geographically separate sites, as shown in Figure 2. The SQLServer database used by VMM should be protected with SQLServer AlwaysOn availability groups with a replica on the secondary site. Ifdisaster occurs the VMM server and its corresponding SQLServer database will automatically fail over to the recovery site,after which all the workloads can be failed over using ASR.
Figure 2
Designing the network address space in a disaster recovery environment
When administrators are planning to deploy a disaster recovery solution, one of the key questions in their mind is how the applicationswill be reachable after the failover is completed. Modern applications are almost always dependent on networking to some degree, so physically moving a service from one site to another represents a networking challenge. There are two main ways that this problem is dealt with in disaster recovery solutions. The first approach is to maintain fixed IP addresses. Despite the services moving and the hosting servers being in different physical locations, applications take the IP address configuration with them to the new location. The second approach involves completely changing the IP address during the transition into the recovered site. Each approach has several implementation variations which are summarized below.
While designing the network for the recovery site, the administrator has two choices:
Option 1: Retain IP addresses
From a disaster recovery process perspective, using fixed IP addresses appears to be the easiest method to implement, but it has a number of potential challenges which in practice make it the least popular approach. Azure Site Recovery provides the capability to retain the IP addresses in all scenarios. Before one decides to retain IP, appropriate thought should be given to the constraints it imposes on the failover capabilities. Let us look at the factors that can help you to make a decision to retain IP addresses, or not. In this category there are two main sub-types: the stretched subnet, and subnet failover. We will separately discuss scenarios when there is a subnet failover or a stretched subnet across two locations.
Stretched Subnet
Here the subnet is made available simultaneously in both primary and DR locations. In simple terms this means you can move a server and its IP (Layer 3) configuration to the second site and the network will route the traffic to the new location automatically. This is trivial to deal with from a server perspective but it has a number of challenges:
- From a Layer 2 (data link layer) perspective,it will require networking equipment that can manage a so-called stretched VLAN, but this has become less of a problem as it is now widely available. The second and more difficult problem is that by stretching the VLAN the potential fault domain is extended to both sites, essentially becoming a single point of failure. While this is an unlikely occurrence, it has happened that a broadcast storm started but could not be isolated. We have found mixed opinions about this last issue and have seen many successful implementations as well as “we will never implement this technology here”.
- Stretched subnet is not possible if you are using Microsoft Azure as the DR site.
Subnet Failover
It is possible to implement subnet failover to obtain the benefits of the stretched subnet solution described above without stretching the subnet across multiple sites. Here any given subnet would be present at Site 1 or Site 2, but never at both sites simultaneously. In order to maintain the IP address space in the event of a failover, it is possible to programmatically arrange for the router infrastructure to move the subnets from one site to another. In a failover scenario the subnets would move with the associated protected VMs. The main drawback to this approach is in the event of a failure you have to move the whole subnet, which may be OK but it may affect the failover granularity considerations.
Let’s examine how a fictional enterprise named Contoso is able to replicate its VMs to a recovery location while failing over the entire subnet. We will first look at how Contoso is able to manage their subnets while replicating VMs between two on-premises locations, and then we will discuss how subnet failover works when Azure is used as the disaster recovery site.
Subnet Failover – Enterprise Grade DR
Let us look at a scenario where we want retain the IP of each of the VMs and fail-over the complete subnet together. The primary site has applications running in subnet 192.168.1.0/24. When the failover happens, all the virtual machines that are part of this subnet will be failed over to the recovery site and retain their IP addresses. Routes will have to be appropriately modified to reflect the fact that all the virtual machines belonging to subnet 192.168.1.0/24 have now moved to the recovery site.
In the following illustration the routes between primary site and recovery site, third site and primary site, and third site and recovery site will have to be appropriately modified. The following assumptions were made for the initial version of this paper:
- Each datacenter is serviced by its own instance of System Center VMM. There will be no replication of the System Center VMM databases between datacenters.
- Each datacenter will make use of static IP addresses for the virtual machines.
- Connectivity between the datacenters is via a dedicated circuit and not via VPN connectivity over the Internet.
Figure 3
Figure 4
When enabling protection for a specific virtual machine, ASR will allocate networking resources according to the following workflow:
- ASR allocates an IP address for each network interface on the virtual machinefrom the static IP address pool defined on the relevant network for each System Center VMM instance.
- If the administrator defines the same IP address pool for the network on the recovery site as that of the IP address pool of the network on the primary site, while allocating the IP address to the replica virtual machine ASR would allocate the same IP address as that of the primary virtual machine. The IP is reserved in VMM but not set as failover IP. Failover IP is set just before the failover.
Figure 5
Figure 5 shows the Failover TCP/IP settings for the replica virtual machine (on the Hyper-V console). These settings would be populated just before the virtual machine is started after a failover
If the same IP is not available, ASR would allocate some other available IP address from the defined IP address pool.
