在AWS上组合使用ELB和Nginx Plus获得更多特性

使用AWS的客户经常问我们,对于负载均衡,到底是使用AWS的ELB还是Nginx Plus?Amazon曾经发布了一个白皮书来说明如何在AWS上配置Nginx Plus。本文将聚焦在选择Nginx Plus或者ELB时需要考虑的因素方面,也会讨论一些更适合于组合使用Nginx Plus和ELB的情形。
1
概述
ELB的设计初衷是提供一套深度集成在AWS之上的高可用基础设施,但是,相对于Nginx Plus所提供的丰富的七层特性来说,ELB稍逊一些。Nginx Plus和ELB在一些特性方面是具有重合性的,这意味着有时选择哪种负载均衡方案也是需要仔细斟酌一下的。
一般来说,结论是这样的:
(1)如果你希望构建简单的负载均衡,同时需要跨AWS可用区和区域的高可用,那么ELB是一个不错的选择;
(2)如果你想要的是一些超过了基本的七层功能特性的负载均衡方案,那么Nginx Plus是一个不错的选择;
(3)如果组合使用Nginx Plus和ELB,那么它们可以提供一套非常完整的解决方案,包括由Nginx Plus组成的主主集群(Active-Active Cluster)等。
下表展示了Nginx Plus和ELB的一些特性对比:

现在我们来讨论Nginx Plus和ELB的一些特性的区别,也会讨论组合使用Nginx Plus和ELB时获得的一些特性。
2
Nginx Plus 的特性
一种只使用Nginx Plus而不使用ELB的典型场景是,在一个单一可用区内部署Nginx Plus即可获得满足应用需要的高可用级别。
如果你在多个AWS区域中有这样的Nginx Plus实例,你可以使用AWS Route 53来分配流量。
以下的七层特性是Nginx Plus所提供但ELB不提供或者功能有限。
2.1、请求路由(Request Routing)
Nginx Plus支持大量的请求路由算法,例如基于URL的特征、请求的头部信息、Cookies字段等。
对于ELB来说,对一个特定DNS域名和端口的请求会无差别的发送到一组后端主机上。
2.2、URL重写和重定向
向后端转发HTTP请求之前,Nginx Plus可以对URL进行重写。在一些场景下,这个功能特别有用,例如URL的静态化,或者你改变了后端文件的位置但不希望改变已发布给客户的URL地址的时候。
Nginx Plus也可以实现URL重定向,例如将所有HTTP请求重定向为HTTPS请求。
2.3、高级的应用健康检查
对于HTTP健康检查来说,你可以使用自定义的URL以及插入HTTP头部字段。你也可以指定检查HTTP响应状态码的同时检查返回体中是否包括特定的字符串等。对于TCP/UDP健康检查来说,你可以指定需要发送的字符串以及需要主机返回的字符串。
对于HTTP和TCP/UDP健康检查来说,你可以指定检查的频率、检查的超时时间以及设置连续多少次检查失败才将节点设置为宕机等。而且你也可以启用Nginx Plus的慢启动特性,也就是当节点恢复后,Nginx Plus会逐渐的向后端增加转发的请求量。
ELB也可以提供HTTP和TCP健康检查,但是你不能设置HTTP响应体或者TCP响应字符串,也不能设置连续多少次检查失败才将节点设置为宕机等。
ELB也不支持对UDP负载均衡和健康检查。
2.4、WebSocket和HTTP/2支持
Nginx Plus可以对WebSocket和HTTP/2应用进行负载均衡和代理。
ELB当前没有这种能力。
2.5、连接和速率限制
Nginx Plus支持多维度的连接和速率限制,例如,限制连入的连接数、限制到后端主机的连接数、进入请求的速率、从Nginx Plus到客户端的数据传输率、从后端主机到Nginx Plus的数据传输率等。
2.6、多种负载均衡算法
Nginx Plus支持丰富的负载均衡算法,例如:轮询、最小连接数、最小连接时间、来源IP散列和其他散列算法等。
3
ElB的特性
如果你不需要使用以上提到的任何Nginx Plus七层特性,那么使用ELB足够了。
以下的特性,是Nginx Plus所不具备而ELB具备的。
3.1、自动伸缩
根据全局的压力情况,ELB可以动态的增加或者缩减后端主机的数量。
3.2、Route 53健康检查是内置集成的
可以启用Route 53来自动的配置和管理ELB的健康检查。
4
组合使用Nginx Plus 和ELB
4.1、主主的高可用
使用ELB来负载均衡Nginx Plus实例时,可以通过创建一组主主实例来获得高可用性。
4.2、自动伸缩Nginx Plus集群
使用ELB的自动伸缩功能,可以动态调整Nginx Plus节点的数量来应对不同的压力。
4.3、自动伸缩后端实例
将ELB放在Nginx Plus之后、后端主机之前,可以使用ELB来自动伸缩后端主机的数量,同时享用Nginx Plus的七层特性。
4.4、访问日志
通过组合使用Nginx Plus和ELB,可以记录更加详细的请求和响应结果。
5
总结
正如以上所讨论的,Nginx Plus和ELB都可以对应用进行负载均衡,不管是独立使用还是组合
使用:
? 如果负载均衡需求比较简单,或者同时需要自动伸缩功能,那么ELB是首选;
? 如果要适配复杂的负载均衡场景,可以使用Nginx Plus或者组合使用Nginx Plus和ELB。
一种典型的Nginx Plus和ELB部署架构如下图所示:

原文地址:https://www.nginx.com/blog/nginx-plus-amazon-elastic-load-balancer-aws/