At the 2020 AWS re:Invent, Amazon Web Services (AWS) discussed best practices for application migration in sessions like The Cutover: Moving Your Traffic to the Cloud.

The presenters discussed how each migration plan should contain 4 primary goals:

  • Zero or minimum downtime
  • Reduced risk of data loss
  • Fast rollback
  • Traffic and log monitoring

Best Practices for Ensuring a Zero Downtime Migration

To achieve these goals, it’s important to correctly perform the traffic cutover.

In ClearScale’s experience, a simple way of migrating is cutover with DNS. To prepare for the migration, we change time-to-live (TTL) to a lower value in advance. That helps resolve new DNS values for all new connections. DNS checking tools can be used to monitor DNS propagation in order to understand which endpoint currently uses the most providers.

But there are a few technical issues you should keep in mind:

  • Some providers could ignore low TTL
  • Persistent connections
  • Browser caching

The most critical points to consider are:

  • The need to use dashboards and monitoring to understand which DNS records are utilized.
  • Amazon Route 53 DNS service can be used for gradual cutover with weighted round-robin, latency-based routing, and geo-based routing. (For example, AWS Route 53 helps to split network traffic: 5% to AWS and 95% to your on-premise environment.)

You can prepare to migrate by using HTTP response status code 301 Moved Permanently for permanent redirects to your environment endpoint in AWS.

Leveraging Amazon CloudFront

Amazon CloudFront content delivery network (CDN) can also help cutover traffic and accomplish a zero  downtime migration in several ways:

  • Cache your on-premise data until you want to switch traffic
  • Switch and propagate to AWS endpoint distribution
  • Use redirect rules within AWS CloudFront
  • Use CloudFront Lambda@Edge code to handle custom redirect rules
  • Perform gradual cutover for stateful applications based on cookies verification
  • Individual components migration

Additional points of interest in using AWS CloudFront for application migrations include:

  • Custom Errors: Generate custom errors and cache error responses
  • Stale Cache: Leverage stale content when the origin is unavailable
  • Original failover: Configure failover on 4хх/5хх errors

Wrap Up – Achieving Zero Downtime Migrations

The most important aspect of migration to AWS is traffic switching and cutover. For most organizations, cutover with zero or minimal downtime is a critical part of the migration. In this post, we’ve shared some best practices which should be added to your application migration plan to help you achieve the goal of zero downtime migration.

As an AWS Premier Consulting Partner with the Migration Competency, ClearScale offers a complete range of cloud services including migrating to the cloud. We can assist with your workload migrations and help you choose the best option for your organization. Contact us to schedule a free consultation with our cloud experts.