AWS 应用程序负载均衡器与网络负载均衡器

Die*_*lez 6 amazon-web-services amazon-alb

我试图了解 ALB(应用程序负载均衡器)和 NLB(网络负载均衡器)之间的主要区别是什么。我知道 ALB 位于 OSI 模型的第 7 层——这意味着它存在于应用程序级别——而 NLB 位于第 4 层,这意味着它在传输级别工作。

也就是说,这意味着 ALB 只能处理 HTTP/HTTPS 请求,不像 NLB 可以处理任何类型的 TCP 请求。

所以我的问题是……仅此而已吗?或者还有其他区别吗?

Joh*_*ley 13

网络负载平衡是基于网络变量(例如 IP 地址和目标端口)的流量分配。它位于第 4 层 (TCP) 及更低层,其设计并未考虑应用程序层的任何内容,例如内容类型、cookie 数据、自定义标头、用户位置或应用程序行为。它是无上下文的,只关心它以这种方式和那种方式定向的数据包中包含的网络层信息。

应用负载均衡是基于多个变量的请求分布,从网络层到应用层。它是上下文感知的,并且可以根据任何单个变量来引导请求,就像它可以使用变量组合一样容易。应用程序根据其特殊行为进行负载平衡,而不仅仅是服务器(操作系统或虚拟化层)信息。

两者之间的区别很重要,因为网络负载平衡不能保证应用程序的可用性。这是因为它仅根据网络和 TCP 层变量做出决定,根本不了解应用程序。通常,网络负载均衡器会根据服务器响应 ICMP ping 或正确完成三向 TCP 握手的能力来确定“可用性”。应用程序负载平衡器更深入,不仅能够根据特定页面的成功 HTTP GET 来确定可用性,还能够根据输入参数验证内容是否符合预期。

当考虑在共享 IP 地址的同一主机上部署多个应用程序(旧 skool 中的虚拟主机)时,这一点也很重要。网络负载均衡器在检查可用性时不会区分应用程序 A 和应用程序 B(实际上它不能,除非端口不同),但应用程序负载均衡器将通过检查可用的应用程序层数据来区分这两个应用程序。这种差异意味着网络负载均衡器最终可能会向崩溃或离线的应用程序发送请求,但应用程序负载均衡器永远不会犯同样的错误。

参考:

网络负载平衡与应用程序负载平衡

  • 我只会说根据 AWS 文档,ALB 具有运行状况检查,因此它可以检查应用程序的可用性,我只会更正这一点,还发现此表很好地解释了每个 LB https://aws.amazon 的好处。 com/elasticloadbalancing/details/?nc1=h_ls (3认同)