基于连接的负载均衡
您可以对 TCP 流量进行负载均衡,从而将连接路由至目标 (Amazon EC2 实例、微服务和容器和 IP 地址)。
高可用性
网络负载均衡器具有高可用性。它接收来自客户端的传入流量,并将此流量分发到同一可用区内的多个目标。负载均衡器还会监控已注册目标的运行状况,并确保只将流量路由到运行良好的目标。当负载均衡器检测到运行状况不佳的目标时,会停止向该目标路由流量,并将流量路由到其他运行良好的目标。如果一个可用区中的所有目标全都运行状况不佳,但您已在其他可用区中设置了目标,则网络负载均衡器会自动执行故障转移,以便将流量路由到其他可用区中运行良好的目标。
高吞吐量
网络负载均衡器设计用于随流量的增加执行流量处理,且每秒可对数百万条请求进行负载均衡。它还可处理突发的不稳定流量模式。
低延迟
网络负载均衡器可为延迟敏感型应用程序提供极低的延迟。
保留源 IP 地址
网络负载均衡器可保留客户端源 IP,从而让后端能够查看客户端的 IP 地址。然后,应用程序可使用该地址进行进一步处理。
静态 IP 支持
网络负载均衡器可自动为每个可用区 (子网) 提供静态 IP,应用程序可将此 IP 用作负载均衡器的前端 IP。
弹性 IP 支持
借助网络负载均衡器,您还可以选择为每个可用区 (子网) 分配静态 IP,从而提供您自己的固定 IP。
运行状况检查
网络负载均衡器同时支持网络和应用程序目标运行状况检查。网络运行状况视您的目标对正常流量的整体响应情况而定。如果目标无法响应新连接或响应太慢,则负载均衡器会将该目标标记为“不可用”。应用程序运行状况检查也可用于进行更深入的了解。它会定期探测给定目标上的特定 URL,从而整合实际应用程序的运行状况。为了实现快速诊断和强大的调试,您还可以通过网络负载均衡器 API 中的“原因代码”和连接到目标运行状况检查的 Amazon CloudWatch 指标,来全面了解运行状况检查以及未通过检查的原因。
DNS 故障转移
如果没有运行状况良好的目标注册网络负载均衡器,或如果给定可用区中的网络负载均衡器节点运行状况不佳,则 Amazon Route 53 会将流量定向到其他可用区中的负载均衡器节点。
与 Amazon Route 53 集成
如果您的网络负载均衡器无法响应,则与 Route 53 的集成将从服务中删除不可用的负载均衡器 IP 地址,并将流量发送到另一个地区的备用网络负载均衡器。
与 AWS 服务集成
网络负载均衡器可与其他 AWS 产品集成,如 Auto Scaling、Amazon EC2 Container Service (ECS)、AWS CloudFormation、AWS CodeDeploy 和 AWS Config。
长期 TCP 连接
网络负载均衡器支持长期 TCP 连接,此类连接非常适用于 WebSocket 类型的应用程序。
集中的 API 支持
网络负载均衡器和应用程序负载均衡器使用的 API 相同。这样一来,您就可以在同一 Amazon EC2 实例的多个端口之间使用目标组、执行运行状况检查并进行负载均衡,从而支持容器化应用程序。
可靠的监控和审核
Amazon CloudWatch 可报告网络负载均衡器的指标。CloudWatch 可提供活动流数量、正常运行的主机数量、新流数量、已处理的字节数等指标。网络负载均衡器还可与 AWS CloudTrail 集成。CloudTrail 可跟踪网络负载均衡器的 API 调用。
增强型日志记录
您可以使用流日志功能来记录发送至负载均衡器的所有请求。流日志捕获有关在您的 VPC 中传入和传出网络接口的 IP 流量的信息。流日志数据使用 Amazon CloudWatch Logs 进行存储。
区域隔离
网络负载均衡器专为单个可用区中的应用程序架构而设计。如果当前可用区中的某些部分出现故障,我们将自动故障转移到其他运行状况良好的可用区。虽然我们建议客户在多个可用区配置负载均衡器和目标以实现高可用性,但网络负载均衡器也可在单个可用区域中启用,以支持需要区域隔离的架构。
使用 IP 地址即目标进行负载均衡
您可以将应用程序后端的 IP 地址用作目标,对 AWS 或本地位置托管的任何应用程序进行负载均衡。这样一来,您就可以对托管在实例上的任意 IP 地址和任意接口上的应用程序后端进行负载均衡。托管在同一实例上的每个应用程序都有关联的安全组,并使用同一端口。此外,您还可以将 IP 地址用作目标,对托管在本地位置 (通过 Direct Connect 连接) 和 EC2-Classic (使用 ClassicLink) 中的应用程序进行负载均衡。通过在 AWS 和本地资源之间进行负载均衡,您可以迁移至云、爆发至云或故障转移至云。