NGINX.COM

High Availability for NGINX Plus on AWS with keepalived and Elastic IP Address

Part of the appeal of cloud computing is the promise of greater uptime. To achieve that, all parts of your architecture must be highly available, including the load balancer. Now you can achieve high availability (HA) for NGINX Plus on AWS with a new solution that combines keepalived and the AWS Elastic IP address feature.

Editor – Since the publication of this post, we have developed an additional solution that combines a highly available active‑active deployment of NGINX Plus with the AWS Network Load Balancer (NLB).

One widely used approach for HA on AWS is to put Elastic Load Balancer (ELB) in front of NGINX Plus instances. While this approach can be a good starting point, using ELB not only increases complexity and cost, but also imposes the following limitations:

  • ELB does not expose a static IP address, which is critical requirement for some applications.
  • ELB IP addresses are published using a DNS CNAME record; you cannot map a root domain (for example, example.com) to a CNAME unless you delegate all DNS to Route 53.
  • ELB does not support UDP, so you cannot take advantage of NGINX Plus’ UDP load balancing.
  • ELB doesn’t scale quickly, so large traffic spikes can result in dropped traffic.

To avoid these limitations, our solution eliminates ELB in favor of a combination of keepalived and an AWS Elastic IP address. An Elastic IP address is a single static IP address assigned to an active‑passive pair of NGINX Plus instances. If the master NGINX Plus instance goes out of service, keeaplived automatically promotes the backup instance to master and transfers the Elastic IP address to it as shown in the figure.

When two NGINX Plus nodes hosted in AWS share an elastic IP address, the address switches to the backup automatically when the master goes down, preserving high availability

For more information, including step‑by‑step instructions, see our Deployment Guide. For information about on‑premises high availability of NGINX Plus, including a solution based on keepalived, see the NGINX Plus Admin Guide.

Editor – For details about our other solution for highly available NGINX Plus on AWS in combination with the AWS Network Load Balancer (NLB), see our Deployment Guide.

New to NGINX Plus on AWS? Try it free for 30 days. For links to the available AMIs, see Installing NGINX Plus AMIs on Amazon EC2.

Cover image
Free O'Reilly Ebook: The Complete NGINX Cookbook

Your guide to everything NGINX

TRY NGINX PLUS!

Download a 30 day free trial and see what you've been missing.

We'll take care of your data.

X

Got a question for the NGINX team?

< back
X

NGINX Controller Free Trial

NGINX Controller is a managed trial for qualified customers.

We'll take care of your data.

X

Tags

No More Tags to display