什么是 应用程序负载均衡器? - Elastic Load Balancing
AWS 文档中描述的 AWS 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 AWS 服务入门

什么是 应用程序负载均衡器?

Elastic Load Balancing 在一个或多个可用区中的多个目标(如 EC2 实例、容器和 IP 地址)之间自动分配传入的流量。它监控已注册目标的运行状况,并且仅将流量路由到正常的目标。Elastic Load Balancing 根据传入的流量随时间的变化对负载均衡器进行扩展。它可以自动扩展来处理绝大部分工作负载。

Elastic Load Balancing 支持以下负载均衡器:Application Load Balancer、Network Load Balancer、网关负载均衡器和 Classic Load Balancer。您可以选择最适合自己需求的负载均衡器类型。本指南讨论 Application Load Balancer。有关其他负载均衡器的更多信息,请参阅 Network Load Balancer 用户指南网关负载均衡器用户指南Classic Load Balancer 用户指南

应用程序负载均衡器 组件

负载均衡器 充当客户端的单一接触点。负载均衡器在多个可用区中的多个目标 (例如 EC2 实例) 间分配应用程序的传入流量。这将提高应用程序的可用性。可以向您的负载均衡器添加一个或多个侦听器。

侦听器 使用您配置的协议和端口检查来自客户端的连接请求。您为侦听器定义的规则确定负载均衡器如何将请求路由到其已注册目标。每条规则由优先级、一个或多个操作以及一个或多个条件组成。当规则的条件满足时,将执行其操作。您必须为每个侦听器定义默认规则,并且可以选择定义其他规则。

每个目标组 使用您指定的协议和端口号将请求路由到一个或多个注册目标,例如 EC2 实例。您可以向多个目标组注册一个目标。您可以对每个目标组配置运行状况检查。在注册到目标组 (它是使用负载均衡器的侦听器规则指定的) 的所有目标上,执行运行状况检查。

下图介绍基本组成部分。请注意,每个侦听器包含一个默认规则,并且一个侦听器包含将请求路由到不同目标组的另一条规则。向两个目标组注册一个目标。


                基本 应用程序负载均衡器 的组成部分

有关更多信息,请参阅以下文档:

应用程序负载均衡器 概述

应用程序负载均衡器在应用程序层正常工作,该层是开放系统互连 (OSI) 模型的第 7 层。负载均衡器收到请求后,将按照优先级顺序评估侦听器规则以确定应用哪个规则,然后从目标组中选择规则操作目标。可以配置侦听器规则,以根据应用程序流量的内容,将请求路由至不同的目标组。每个目标组的路由都是单独进行的,即使某个目标已在多个目标组中注册。可以配置目标组级别使用的路由算法。默认路由算法为轮询路由算法;或者,可以指定最少未完成请求路由算法。

可以根据需求变化在负载均衡器中添加和删除目标,而不会中断应用程序的整体请求流。Elastic Load Balancing 根据传输到应用程序的流量随时间的变化对负载均衡器进行扩展。Elastic Load Balancing 能够自动扩展以处理绝大部分工作负载。

您可以配置运行状况检查,这些检查可用来监控注册目标的运行状况,以便负载均衡器只能将请求发送到正常运行的目标。

有关更多信息,请参阅 Elastic Load Balancing 用户指南 中的 Elastic Load Balancing 工作原理

从 传统负载均衡器 迁移的好处

使用 应用程序负载均衡器 而不是 传统负载均衡器 具有以下优势:

  • 支持 路径条件。对于根据请求中的 URL 转发请求的侦听器,您可以为它配置规则。这让您可以将应用程序构造为较小的服务,并根据 URL 内容将请求路由到正确的服务。

  • 支持 主机条件。对于基于 HTTP 标头中主机字段转发请求的侦听器,您可以为它配置规则。这使您能够使用单个负载均衡器将请求路由到多个域。

  • 支持基于请求中的字段进行路由,例如 HTTP 标头条件 和方法、查询参数和源 IP 地址。

  • 支持将请求路由到单个 EC2 实例上的多个应用程序。可以使用多个端口向同一个目标组注册每个实例或 IP 地址。

  • 支持将请求从一个 URL 重定向到另一个 URL。

  • 支持返回自定义 HTTP 响应。

  • 支持通过 IP 地址注册目标,包括位于负载均衡器的 VPC 之外的目标。

  • 支持将 Lambda 函数注册为目标。

  • 支持负载均衡器在路由请求之前使用应用程序用户的企业或社交身份对这些用户进行身份验证。

  • 支持容器化的应用程序。计划任务时,Amazon Elastic Container Service (Amazon ECS) 可以选择一个未使用的端口,并可以使用此端口向目标组注册该任务。这样可以高效地使用您的群集。

  • 支持单独监控每个服务的运行状况,因为运行状况检查是在目标组级别定义的,并且许多 CloudWatch 指标是在目标组级别报告的。将目标组挂载到 Auto Scaling 组的功能使您能够根据需求动态扩展每个服务。

  • 访问日志包含附加信息,并以压缩格式存储。

  • 已改进负载均衡器性能。

有关每个负载均衡器类型支持的功能的更多信息,请参阅 Elastic Load Balancing 的产品比较

Elastic Load Balancing 可与以下服务一起使用来提高应用程序的可用性和可扩展性。

  • Amazon EC2 — 在云中运行应用程序的虚拟服务器。您可以将负载均衡器配置为将流量路由到您的 EC2 实例。

  • Amazon EC2 Auto Scaling — 确保运行所需数量的实例(即使实例失败也是如此),并可让您根据实例需求的变化自动增加或减少实例数。如果您使用 Elastic Load Balancing 启用 Auto Scaling,则 Auto Scaling 启动的实例将自动向负载均衡器注册,并且 Auto Scaling 终止的实例将自动从负载均衡器注销。

  • AWS Certificate Manager — 在创建 HTTPS 侦听器时,您必须指定由 ACM 提供的证书。负载均衡器使用证书终止连接并解密来自客户端的请求。有关更多信息,请参阅 SSL 证书

  • Amazon CloudWatch — 使您能够监控负载均衡器并执行所需操作。有关更多信息,请参阅 应用程序负载均衡器 的 CloudWatch 指标

  • Amazon ECS — 使您能够在 EC2 实例集群上运行、停止和管理 Docker 容器。您可以将负载均衡器配置为将流量路由到您的容器。有关更多信息,请参阅 Amazon Elastic Container Service Developer Guide 中的服务负载均衡

  • AWS Global Accelerator — 提高应用程序的可用性和性能。使用加速器在一个或多个 AWS 区域的多个负载均衡器之间分配流量。有关更多信息,请参阅 AWS Global Accelerator 开发人员指南

  • Route 53 — 通过将域名(如 www.example.com)转换为计算机相互连接所用的数字 IP 地址(如 192.0.2.1),以一种可靠且经济的方式将访问者路由至网站。AWS 将向您的资源 (如负载均衡器) 分配 URL。不过,您可能希望使用方便用户记忆的 URL。例如,您可以将域名映射到负载均衡器。

  • AWS WAF — 您可以结合使用 AWS WAF 和 应用程序负载均衡器 以根据 Web 访问控制列表 (Web ACL) 中的规则允许或阻止请求。有关更多信息,请参阅 Application Load Balancer 和 AWS WAF

要查看与负载均衡器集成的服务的信息,请在 AWS 管理控制台中选择负载均衡器,并选择 Integrated services (集成的服务) 选项卡。

定价

利用负载均衡器,您可以按实际用量付费。有关更多信息,请参阅 Elastic Load Balancing 定价