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

在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的一些特性对比:

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

现在我们来讨论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部署架构如下图所示:

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

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

了解新钛云服

告别前任,从薪出发。

招聘|挑战百万年薪

TiOps,支持多云环境安全远程运维,疫情期间免费对外开放,助力远程安全办公!

新钛云服正式获批工信部ISP/IDC(含互联网资源协作)牌照

深耕专业,矗立鳌头,新钛云服获千万Pre-A轮融资

新钛云服,打造最专业的Cloud MSP+,做企业业务和云之间的桥梁

新钛云服一周年,完成两轮融资,服务五十多家客户

上海某仓储物流电子商务公司混合云解决方案

新钛云服出品的部分精品技术干货

国内主流公有云VPC使用对比及总结

万字长文:云架构设计原则|附PDF下载

刚刚,OpenStack 第 19 个版本来了,附28项特性详细解读!

Ceph OSD故障排除|万字经验总结

七个用于Docker和Kubernetes防护的安全工具

运维人的终身成长,从清单管理开始|万字长文!

OpenStack与ZStack深度对比:架构、部署、计算存储与网络、运维监控等

什么是云原生?

IT混合云战略:是什么、为什么,如何构建?

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