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

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

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

话虽如此,这意味着 ALB 只能处理 HTTP/HTTPS 请求,而不像 NLB 可以处理任何类型的 TCP 请求。

所以我的问题是...就这些吗?还是还有其他区别?

答案1

网络负载平衡是基于网络变量(例如 IP 地址和目标端口)的流量分配。它位于第 4 层 (TCP) 及以下,不考虑应用层的任何内容,例如内容类型、Cookie 数据、自定义标头、用户位置或应用程序行为。它不考虑上下文,只关心它所引导的数据包中包含的网络层信息。

应用程序负载平衡是基于从网络层到应用程序层的多个变量来分配请求。它具有上下文感知能力,可以根据任何单个变量或多个变量的组合轻松引导请求。应用程序的负载平衡基于其特殊行为,而不仅仅是基于服务器(操作系统或虚拟化层)信息。

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

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

参考:

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

相关内容