当前位置:首页 > 技术文章 > 正文内容

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

arlanguage5个月前 (12-15)技术文章45


使用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/

扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/202.html

标签: nginx访问慢
分享给朋友:

“在AWS上组合使用ELB和Nginx Plus获得更多特性” 的相关文章

linux(centos)yum安装nginx最新版及配置文件

安装nginx及配置文件我们采用yum的方式安装最新版nginx,就两步即可。最新版本及其他Linux版本可见官方文档官方文档:http://nginx.org/en/linux_packages.html#stable请读者根据自己的版本选择配置:按官方文档,选择自己版本centos可看到步骤:1...

Welcome to nginx!

If you see this page, the nginx web server is successfully installed and working. Further configuration is required.For online documentation and suppo...

Nginx:为什么高性能?Master&worker如何配合?负载均衡了解吗?

1. Nginx架构及工作流程Nginx真正处理请求业务的是Worker之下的线程。worker进程中有一个ngx_worker_process_cycle()函数,执行无限循环,不断处理收到的来自客户端的请求,并进行处理,直到整个Nginx服务被停止。当一个 worker 进程在 accept()...

网页上出现503 Service Unavailable Error应该如何处理?

本头条号每天坚持更新原创干货技术文章,欢迎关注本头条号"Linux学习教程",公众号名称“Linux入门学习教程"。如需学习视频,请复制以下信息到手机浏览器或电脑浏览器上:zcwyou.com1. 前言在浏览网页时,最常见的错误之一是“503 Service Unavaila...

网站加载慢?让你的网站腾飞起来,LiteSpeed部署

说起LiteSpeed 还得说起我的小站,<开心洋葱网>,虽然流量不大,但是访问是真的慢,无奈经费有限,那就只能在服务器加速上动起心思来。之前一直听说 QUIC 访问网站的速度会让你感觉飞起来,那就搞下吧。我们先来看下 QUIC 、LiteSpeed都是些做什么的?QUIC(Quick...

平稳运行半年的系统宕机了,记录一次排错调优的全过程

(一)前言最近发生了一件很让人头疼的事情,已经上线半年且平稳运行半年系统在年后早高峰的使用时发生了濒临宕机的情况。访问速度特别慢,后台查到大量time_wait的连接,从代码层面到架构层面到网络层面排查了几天几夜,总算是有了结果。(二)架构、问题描述先简单描述一下这个系统的架构,公网域名对应的公网I...