这是一个例子。有一个 docker 容器 A(比如连接到后端的服务)。我正在从 docker 映像 B 运行多个容器(比如通过服务连接到后端的前端)。现在,我想将所有容器从 B(B1、B2、B3 等)链接到容器 A。
如何在 ECS 中实现上述目标?如果我在单个任务定义中创建两个容器(A 和 B),那么在运行此任务的多个服务时将同时运行 A 和 B 的多个容器。
请注意,我正在使用 CloudFormation 来实现上述目的。
提前致谢。
这是一个例子。有一个 docker 容器 A(比如连接到后端的服务)。我正在从 docker 映像 B 运行多个容器(比如通过服务连接到后端的前端)。现在,我想将所有容器从 B(B1、B2、B3 等)链接到容器 A。
如何在 ECS 中实现上述目标?如果我在单个任务定义中创建两个容器(A 和 B),那么在运行此任务的多个服务时将同时运行 A 和 B 的多个容器。
请注意,我正在使用 CloudFormation 来实现上述目的。
提前致谢。
最简单的方法是创建多个 ECS 服务。您可以在同一个集群或不同集群中创建它们(这实际上取决于您希望如何设置基础架构)。将容器 B 的服务放在应用程序负载均衡器之后,然后让负载均衡器在来自容器 A 的请求期间处理连接到各个容器。要在 CloudFormation 中执行此操作,您需要创建以下 CloudFormation 资源类型:
AWS::ElasticLoadBalancingV2::LoadBalancer
AWS::ElasticLoadBalancingV2::TargetGroup
AWS::ElasticLoadBalancingV2::Listener
基本上,您会将这些资源类型中的每一种都添加到您的 CloudFormation 模板中。资源将通过以下方式相互引用:
请注意,您可以使用“Scheme”属性将 AWS::ElasticLoadBalancingV2::LoadBalancer 资源设置为内部资源或面向 Internet。如果您想保持服务 B 私有,只需将其设置为“内部”。
当然,您还需要添加各种资源类型来构建 ECS 集群/服务的其余部分,但我假设您的模板中已经有了这一部分。
部署 CloudFormation 堆栈更改后,负载均衡器将有一个 URL(您可以使用“Fn::GetAtt”将其添加到堆栈的输出中:[“LogicalIDOfLBResource”,“DNSName”] -请参阅“DNSName”在此处的文档中返回值)。当您向该 URL 发出请求时,负载均衡器将自动连接到任何 B 容器并从容器返回响应,因此您可以在 A 容器中使用此 URL 从 A 连接到 B。