Azure and LISP for Workload Migration
Workload migrations to a public cloud such
as Azure involve careful planning and coordination between multiple teams,
including application, server, network, and storage teams.
One of the challenges the teams face is
dealing with IP address changes. An IP address change to an application
can cause unnecessary complexity and delay to the project. For example, some
applications, have IP addresses hard-coded, therefore, introduces risk with
having to rewrite an application. What if you could migrate workloads to
Azure with IP mobility keeping the original IP address without network
constraints? IP mobility allows you to separate the workload migration
from network limitations. For instance, if the team can’t migrate all
workloads within a subnet during a change window than the subnet can co-exist
in your data center and Azure during the migration. A migration
team can migrate workloads in small groupings, enabling even a single-server
migration.
This blog describes a solution for data
center migration to Azure using Cisco® Locator/ID Separation Protocol
(LISP) technology (RFC 6830).
LISP
The
Locator Identity Separation Protocol (LISP) is a routing architecture that
creates a new paradigm by splitting the device identity, known as an Endpoint
Identifier (EID), and its location, known as its Routing Locator (RLOC), into
two different numbering spaces. This capability brings scale and flexibility to
the network in a single protocol, enabling the areas of mobility, scalability,
and security. For enterprises moving to Azure, LISP provides key benefits such
as IP Mobility for Public IP Address Portability, Split Subnets during Data
Center Migration, Geographic Dispersion of Data Centers and Disaster Recovery.
This document focuses on LISP use cases addressing today’s enterprise data
center use-cases when migrating to Azure. Workload virtualization
requires location independence for server resources and requires the
flexibility to move these server resources from one data center to another to
meet increasing workloads and to support disaster recovery. This brings the
challenge of route optimization when the Virtual Servers move to route traffic
to its current location. It also to keep the server’s identity (IP address) the
same across moves, so the clients can continue to send traffic regardless of
the server’s current location. The LISP VM-Mobility solution addresses this
issue seamlessly by enabling IP end-points to change location while keeping
their assigned IP addresses. The Virtual Servers may move between different
subnets or across different locations of a subnet that has been moved via Azure
ARM or Azure Migration Tools. In either case, the LISP VM-Mobility
solution guarantees optimal routing between clients and the IP end-point that
moved, regardless of its location. Also, LISP VM-Mobility does not require any
change in the DNS infrastructure (since the mobile nodes preserve their
original IP addressing), which overall reduces operating expenses for the data
center administrator.
LISP is a
routing architecture, not a feature; it gives IP a full set of capabilities
that it does not natively have. LISP enables IP address portability, which can
be seen in two ways. First, it allows the mobility of a host anywhere without
changing the host IP address. Second, it allows defining an edge host IP
address independently from the site IP structure it will reside on. The
decoupling of the application definition from the network is critical for cloud
flexibility.
IP
Mobility Requirements
The goal
of IP mobility is to steer traffic to the valid location of the end-point. This
aspect is generally addressed by providing some sort of re-direction mechanism
to enhance the traffic steering already provided by basic routing. Redirection
can be achieved by replacing the destination address with a surrogate address
that is representative of the new location of the end-point. For instance, what
VNET or Region does my workload currently reside in? A goal of IP
mobility is to provide a solution that is transparent to the applications and
allows for the preservation of established sessions, as end-points move around the
IP infrastructure.
Terminology:
In
traditional IP, the IP edge routing subnets are advertised all over the network
using either an Interior Gateway Protocol (IGP) or an Exterior Gateway Protocol
(EGP); it is very rare to advertise any host address (subnet mask /32). With
LISP, such constraints disappear; LISP splits the host ID (EID) from the RLOC,
allowing any host to move from location to location while keeping its unique
identity. LISP architecture is composed of several elements, including the following:
Locator/ID Separation Protocol (LISP): A tunnel protocol that uses a central database in
which endpoint location is registered. LISP enables an IP host-based mobility
of endpoints.
LISP-enabled virtualized router: A virtual machine or appliance that supports routing
and LISP functions, including host mobility.
Endpoint ID (EID): IPv4 or IPv6 identifier of the devices connected at
the edge of the network and used in the first (most inner) LISP header of a
packet.
Routing Locator (RLOC): IPv4 or IPv6 addresses used to encapsulate and
transport the flow between LISP nodes. An RLOC is the
output of an EID-to-RLOC mapping lookup.
Ingress
tunnel router (ITR): A router that
has two functions: it resolves the location of an EID by querying the database,
and then it performs the encapsulation toward the remote RLOC. Sends
requests toward the map resolver. Populates its local map cache with the
learned association. Responsible for performing the LISP encapsulation
Egress
tunnel router (ETR): A router that
has two functions: it registers the endpoint or location associated with the
database, and then it decapsulates the LISP packet and forwards it to the right
endpoint. It registers the EID address space it is authorized for, and It
is identified by one (or more) RLOCs
xTR: A
generic name for a device performing both ITR and ERT functions.
Proxy-ITR (PITR): Acts like an ITR but does so on behalf of non-LISP
sites that send packets to destinations at LISP sites.
Proxy-ETR (PETR): Acts like an ETR but does so on behalf of LISP sites
that send packets to destinations at non‑LISP sites.
PxTR: The
point of interconnection between an IP network and a LISP network, playing the
role of ITR and ETR at this peering point.
Map-Server (MS): A MS is a LISP Infrastructure device that LISP site
ETRs register to with their EID prefixes. The MS advertises aggregates for the
registered EID prefixes into the LISP mapping system. All LISP sites use the
LISP mapping system to resolve EID-to-RLOC mappings. This server is the
database where all EID and RLOC associations are stored. It can be
deployed simply on a pair of devices. Or it can be a hierarchy of
devices, organized like a DNS system for massive scale implementation.
Map-Resolver
(MR): An MR is a LISP Infrastructure
device to which LISP site ITRs send LISP Map-Request queries when resolving
EID-to-RLOC mappings. Receives the request and selects the appropriate
map server
LISP
Use-Cases
Use-Case
|
Requirements
|
Fast Bring-up of Disaster Recovery
Facilities
|
Relocation of IP end-points to
Azure without IP address change.
|
DC Migration
|
Relocation of IP end-points to
Azure without IP address change.
|
Relocation of Public IP Address
across organizations
|
DC
Migration
This document is focused on DC Migration. The concept of the solution is to
use an Azure Availability Set of Cisco CSR 1000V virtual routers within an
Azure VNET, and a LISP-enabled router pair (Cisco ASR 1000 Series Aggregation
or Cisco CSR 1000V virtual routers) deployed in the enterprise data center with
a LISP (encrypted optional) tunnel in between. LISP provides the mobility
between the two or more sites, allowing you to stretch subnets from the
enterprise to an Azure VNET.
Non-LISP-enabled sites communicate to the servers
moved to Azure through the enterprise data center, where LISP is deployed.
The solution proposed in this paper does
not require LISP to be enabled globally; it can be deployed by enabling LISP on
just the enterprise data center and within Azure, with minimal impact on the
operations of both the data center and Azure.
The optional deployment of LISP at
individual user's sites provides data-path optimization because the
LISP-encapsulated traffic is routed directly Azure or the data center,
depending on the server location.
The LISP-enabled router deployed within the
enterprise data center does not need to be the default gateway for the local
servers (physical and virtual machines). The LISP enabled router is deployed
“on a stick,” meaning that it does not need to be the
default gateway, and its interaction with the local infrastructure is based on Proxy-ARP. The router has at
least two interfaces facing the data center, one as the routed core interface
and one for Layer 2 collection of VLANs. The stretched subnets are locally
either connected using sub-interfaces.
The LISP CSRs in Azure is deployed with one interface facing the
Internet or facing Gateway Subnet and the other interfaces facing the local
Azure Subnets. The stretched subnets are
connected by the interfaces that face the local Azure subnets.
The LISP-enabled Azure solution allows
inter and intra-subnet communication regardless of the location of the server, meaning
that communication between two endpoints located in different subnets can
happen even when one endpoint is located at the enterprise, and another
endpoint is located at Azure with a stretched subnet between enterprise and
Azure.
Routing Considerations
In any case, DC Migration solution requires
only that each CSR have one unique outside address; then an IPsec tunnel is
built between these addresses, and the IPsec tunnel has a private address.
In the DC Migration solution, an OSPF peering
is enabled over this GRE/IPsec tunnel. The objective is to announce to the
other CSR the loopback address that is used as the LISP location (RLOC). Now,
enabling a routing protocol could allow you to advertise some subnet of the
cloud that does not need mobility and could not be subject to LISP handling.
The transport service in the WAN side is
usually of two types. It could be a plain public Internet network, or it could
be private peering over ExpressRoute. Both transport services are supported.
With the Internet, an important consideration is the NAT service. NAT is
sometimes used between Azure and the transport network, and most probably the
same occurs on the enterprise side. Because IPsec supports NAT, the fact that
this solution uses IPsec as a tunnel connection between the enterprise and
Azure solves any NAT burden. In the IPsec tunnel, as well as in the cloud, the
private enterprise addressing is used, and LISP operates over these private
addresses. With the ExpressRoute option, because all addresses are in a private
space, no NAT considerations are necessary.
LISP Stretched Subnets Advertisement
The subnets that will be stretched from the
enterprise to Azure already exist within the enterprise data center. Those
subnets should already be advertised toward the enterprise WAN by the existing
routing protocol to ensure that non-LISP remote sites have a route to the
LISP-enabled subnets through the enterprise data center, where PxTR-1 attracts
all the traffic directed to the subnets that have been "stretched" to
Azure.
Reference Topology
The reference topology has three
environments: An enterprise branch office (remote site), an enterprise data
center, and Azure.
The branch-office subnet where users
connect is 10.0.100/24. The users’ default gateway is the router (Router
1) with IP address 10.0.100.10. Router 1is connected to the Internet with a VPN
to the enterprise DC or via a private WAN. Router 1 does not run LISP, so
the branch office is a non-LISP site. Branch-office users access servers
located either at the enterprise data center or at Azure.
The enterprise data center is connected to
the Internet or private WAN through the data center WAN edge routers (Router A
& B) The default gateway for all the servers located in the enterprise data
center is at the aggregation layer; on the diagram 10.0.5.0/24 is the only
subnet represented for simplicity. The Cisco CSR 1000V or Cisco ASR
installed on the enterprise, PxTR-1, has two interfaces. The blue link is the
connecting towards the Internet or WAN, and the black link is the PxTR-1
connection to the 10.0.5.0/24 subnet where mobility is required.
PxTR-1 is the only device within the
enterprise data center running LISP, and it is configured as a LISP PxTR.
PxTR-1 is also configured with a GRE/IPsec tunnel toward the Azure CSR. OSPF is
enabled over the IPsec tunnel to advertise the IP address of the loopback
interfaces of PxTR-1 and CSR that are used as the LISP RLOCs.
The (CSR) deployed on Azure has one public
IP address, and one or more interfaces with private addresses, one interface
configured with IP 10.1.50.x. A virtual machine with IP address
10.0.5.253 has been moved to Azure; it uses the IP address 10.0.5.1 (Azure
Fabric) as its default gateway. The subnet has a UDR pointing to the CSR
for subnets still within the Enterprise it needs to reach.
CSR is the only device in the Azure running
LISP, and it is configured as a LISP xTR. CSR is also configured with a
GRE/IPsec tunnel toward PxTR-1, the enterprise data center CSR, and it has OSPF
enabled over its IPsec tunnel to advertise its loopback interface address that
is used as its RLOC. In the topology, the subnet 10.0.5.0/24 is stretched
between the enterprise data center, Azure. The IPsec tunnel between the
enterprise and cloud CSRs is used to secure communication between the
enterprise and the cloud.
Implementation Details within Azure
The Azure CSR is configured
as a LISP ITR and ETR node so that it can perform LISP encapsulation and
de-encapsulation of the packets coming from or going to the virtual machines
located within Azure. For traffic leaving Azure, whenever a route to the
destination is not found on the CSR routing table, CSR must route that traffic
through PxTR-1 at the enterprise data center. This function, known as use-petr,
is useful to ensure that the traffic flow is symmetric between non-LISP-enabled
sites and Azure, and it must be used when firewalls or other stateful devices
are located at the enterprise data center.
Packet Walk and Encapsulation Stack
This
section explains the detailed communication flows referring to the diagram
shown in Figure above earlier in this document. PxTR-1, at the enterprise data
center, is placed on a stick. PxTR-1 proxy replies on behalf of all nonlocal
servers, inserting its own MAC address for any EID that is not locally
detected. PxTR-1 can be either a physical router (Cisco ASR 1000) or a virtual
router (Cisco CSR 1000V). PxTR -1 is enabled as a LISP PiTR so you can manage
both locally sourced traffic and traffic coming from the WAN. PxTR-1 is also
set up as a LISP PeTR so you can receive traffic back from Azure and deliver it
to the WAN. At Azure, the CSR (xTR) is a standard LISP xTR for the
locally attached subnets. Azure CSR xTR plays the role of eTR for the
flow coming from the enterprise site and acts as an iTR for the flow going back
to the enterprise site. For any destination that is not known by the xTR, the
iTR encapsulates the traffic to the RLOC of the PeTR specified, in this case,
the PxTR-1 deployed at the enterprise site.
Communication from Non-LISP-Enabled
Remote Sites to Enterprise and Azure
Traffic from user PCs, which are located at
a remote site that is not LISP-enabled, is naturally attracted toward the
enterprise data center by IP routing. When it reaches the enterprise site, it
crosses the site's security and other services to reach the local subnet that
is supposed to host the destination server 10.0.5.253. When the local default
gateway sends an ARP request to find .253, PxTR-1 responds to this ARP request
using the Proxy-ARP function as described previously. Traffic is sent
LISP-encapsulated to Azure, where it is delivered to CSR (xTR), which is the
LISP gateway for (.253), handles the return traffic that is sent by .253.
Because this traffic is intended for a non-LISP site, Azure CSR sends the
traffic to the PeTR configured on it (PxTR-1).
Communication from Enterprise Local
LISP-Enabled Subnet to the Azure LISP-Enabled Subnet
Traffic originated from a LISP-enabled
subnet (non-10.0.5.0/24) intended for another LISP-enabled subnet and further
extended to Azure (to .253) first reaches the local gateway and then will be
routed locally to the extended subnet where PxTR-1 will respond to the ARP
request. On the return path, the traffic will hit Azure CSR, which is the LISP
gateway and then be routed by LISP toward the enterprise site.
Communication from Enterprise Local
Non-LISP-Enabled Subnet to Azure LISP-Enabled Subnet
In this case, traffic will first reach the
default gateway, from which it will follow the same path as the traffic
originated from a remote site. The PxTR function will be used in both
directions.
Communication from LISP-Enabled Subnets
to Non-LISP-Enabled Subnets
Traffic sourced from a LISP-enabled subnet
at the enterprise site toward a non-LISP-enabled subnet at Azure, standard
routing will take effect. Communication sourced from VMs in Azure will be
LISP encapsulated to the PxTR in the Customer DC, and the the PxTR will follow
standard routing.
Communication between Non-LISP-Enabled
Subnets
In this case, the traffic will be routed
using plain IP routing, and LISP is not involved. The return traffic also uses
plain IP routing, and LISP is not involved. Inter-Subnet
Communication between Servers in Azure
In Azure itself, Azure fabric will route traffic
between local subnets because it is the default gateway. CSR can
optionally route traffic between LISP enabled subnets because it is the Azure
LISP gateway.
Communication from LISP-Enabled Remote
Sites to Enterprise and Cloud
All previous considerations of traffic
flows assume that the only LISP-enabled devices are PxTR-1 and xTR-2. If one
remote site needs to access directly a non-LISP-enabled resource in Azure,
meaning a subnet that is strictly local to Azure, then pure routing can be
used. If a remote site needs path optimization to directly reach the servers
that are part of a LISP stretched subnet at Azure, LISP can be enabled on this
remote site. An xTR deployed on this remote site would consult the map server
to receive the correct location of the server. If Azure vWAN is used than
a LISP-enabled branch would have an optimized path for LISP stretched subnets
during DC migration.
References:
Thank you for the informative post about Security challenges in AWS , Found it useful . cloud migration services have now become secured and with no-risk
ReplyDeleteCloud Migration services
Aws Cloud Migration services
Azure Cloud Migration services
This is a nice article you shared great information I have read it thanks for giving such a wonderful Blog for the reader.
ReplyDeleteSQL Azure Online Training
Azure SQL Training
SQL Azure Training
On Enterprise DC CSR, don't we need to configure the LAN interface (Gig 2) with an IP from subnet 10.0.5.0/24 ?
ReplyDeleteI am really impressed with the information that is provided in this blog about digital transformation services such as additional man power and mitigation of risk etc.
ReplyDeleteazure cloud migration services
Bardzo fajnie napisane. Jestem pod wrażeniem i pozdrawiam.
ReplyDeleteThere are a number of different types of data that may be involved in adatabase migration processIt may be a simple copy of the entire database, or it may involve copying selected data only. It may require just the data and a few configuration settings, or it may require the database schema as well. It may be necessary to convert the data from one format to another, depending on the detail of the change.
ReplyDeleteNice Post.Valuable and interesting information.
ReplyDeleteDevOps Training
DevOps Online Training
azure online training in hyderabad
ReplyDeletems azure online training
Excellent article... Thank you for providing such valuable information; the contents are quite intriguing. Keep Posting more on
ReplyDeleteData Engineering Services
Data Analytics Solutions
Data Modernization Solutions
AI & ML Service Provider
Thanks for more information in Azure Cloud Migration Services & Solutions | TOS
ReplyDeleteThis comment has been removed by the author.
ReplyDeleteThe information you've shared on Azure Migration has really pleased me. It's a fascinating article, both for me and for others. Thank you for bringing such interesting topics to our attention.
ReplyDeleteNice and informative post. Most of the IT sectors prefers cloud solutions for their organization. Cloud migration services helps for the companies to move the next level. Keep sharing more content like this.
ReplyDeleteNice blog...mobile cloud computing
ReplyDeleteThis comment has been removed by the author.
ReplyDeleteThis comment has been removed by the author.
ReplyDeleteAs a software developer with a keen interest in cloud technologies, I found your article on utilizing Azure and LISP for workload migration truly insightful. The marriage of Azure's robust infrastructure and the elegance of LISP's programming language presents an exciting prospect for streamlining migration processes.
ReplyDeleteAzure's scalability and reliability have long been acknowledged, but your exploration of how LISP can enhance this ecosystem adds a new dimension. The flexibility and expressiveness of LISP are ideal for orchestrating complex migration tasks, ensuring efficiency and minimizing downtime.
Moreover, your discussion on leveraging Azure's services such as Azure Database Migration Service alongside LISP's capabilities highlights a practical approach to addressing the challenges of workload migration. This combination not only simplifies the migration process but also opens doors to innovative solutions that harness the full potential of Azure.
Overall, your article underscores the importance of strategic integration between cloud platforms like Azure and versatile programming languages like LISP. It's a testament to the ever-evolving landscape of technology and the boundless opportunities it presents for optimizing workflows and driving business success. Kudos on shedding light on this compelling synergy!
And for more details book a free demo with us https://forgeahead.io/lets-talk/