5

这是一个例子。有一个 docker 容器 A(比如连接到后端的服务)。我正在从 docker 映像 B 运行多个容器(比如通过服务连接到后端的前端)。现在,我想将所有容器从 B(B1、B2、B3 等)链接到容器 A。

如何在 ECS 中实现上述目标?如果我在单个任务定义中创建两个容器(A 和 B),那么在运行此任务的多个服务时将同时运行 A 和 B 的多个容器。

请注意,我正在使用 CloudFormation 来实现上述目的。

提前致谢。

4

1 回答 1

0

最简单的方法是创建多个 ECS 服务。您可以在同一个集群或不同集群中创建它们(这实际上取决于您希望如何设置基础架构)。将容器 B 的服务放在应用程序负载均衡器之后,然后让负载均衡器在来自容器 A 的请求期间处理连接到各个容器。要在 CloudFormation 中执行此操作,您需要创建以下 CloudFormation 资源类型:

AWS::ECS::服务

AWS::ElasticLoadBalancingV2::LoadBalancer

AWS::ElasticLoadBalancingV2::TargetGroup

AWS::ElasticLoadBalancingV2::Listener

基本上,您会将这些资源类型中的每一种都添加到您的 CloudFormation 模板中。资源将通过以下方式相互引用:

  • AWS::ECS::Service -> TargetGroup 的 ARN(在 LoadBalancers 属性中)
  • AWS::ElasticLoadBalancingV2::Listener -> LoadBalancer 的 ARN(LoadBalancerArn 属性),TargetGroup 的 ARN(在 DefaultActions 属性中)

请注意,您可以使用“Scheme”属性将 AWS::ElasticLoadBalancingV2::LoadBalancer 资源设置为内部资源或面向 Internet。如果您想保持服务 B 私有,只需将其设置为“内部”。

当然,您还需要添加各种资源类型来构建 ECS 集群/服务的其余部分,但我假设您的模板中已经有了这一部分。

部署 CloudFormation 堆栈更改后,负载均衡器将有一个 URL(您可以使用“Fn::GetAtt”将其添加到堆栈的输出中:[“LogicalIDOfLBResource”,“DNSName”] -请参阅“DNSName”在此处的文档中返回值)。当您向该 URL 发出请求时,负载均衡器将自动连接到任何 B 容器并从容器返回响应,因此您可以在 A 容器中使用此 URL 从 A 连接到 B。

于 2018-05-29T08:06:36.887 回答