AWS ECS:部署了多个容器,但只有一个监听80端口的容器是可发现的。
创始人
2024-11-15 19:31:47
0

要解决这个问题,您可以使用AWS Elastic Load Balancer(ELB)来将流量路由到多个容器上的监听80端口。

以下是一个使用AWS Application Load Balancer(ALB)的示例,将流量路由到多个ECS容器上的监听80端口:

  1. 创建一个ECS集群,用于托管您的容器。您可以使用以下命令创建一个ECS集群:
aws ecs create-cluster --cluster-name my-cluster
  1. 创建一个或多个ECS任务定义,其中包含要部署的容器的配置。确保在任务定义中为每个容器指定不同的主机端口,以便它们可以在同一EC2实例上运行。
aws ecs register-task-definition \
  --family my-task-definition \
  --network-mode awsvpc \
  --requires-compatibilities FARGATE \
  --execution-role-arn ecsTaskExecutionRoleArn \
  --container-definitions '[{
      "name": "container-1",
      "image": "your-container-1-image",
      "portMappings": [{
          "containerPort": 80,
          "hostPort": 8080
      }]
  },
  {
      "name": "container-2",
      "image": "your-container-2-image",
      "portMappings": [{
          "containerPort": 80,
          "hostPort": 8081
      }]
  }]'
  1. 创建一个ALB,用于将流量路由到ECS容器。您可以使用以下命令创建一个ALB:
aws elbv2 create-load-balancer \
  --name my-load-balancer \
  --subnets subnet-1 subnet-2 \
  --security-groups sg-1
  1. 创建一个目标组,用于将ALB路由到ECS容器。在目标组中,将监听器端口设置为80,并将容器端口与主机端口匹配。
aws elbv2 create-target-group \
  --name my-target-group \
  --protocol HTTP \
  --port 80 \
  --vpc-id your-vpc-id \
  --target-type ip \
  --health-check-protocol HTTP \
  --health-check-path /health

aws elbv2 register-targets \
  --target-group-arn target-group-arn \
  --targets Id=your-container-instance-id1,Port=8080 Id=your-container-instance-id2,Port=8081
  1. 创建一个ALB监听器,将流量从ALB路由到目标组。
aws elbv2 create-listener \
  --load-balancer-arn load-balancer-arn \
  --protocol HTTP \
  --port 80 \
  --default-actions Type=forward,TargetGroupArn=target-group-arn
  1. 部署ECS任务并将其与目标组关联。
aws ecs create-service \
  --cluster my-cluster \
  --service-name my-service \
  --task-definition my-task-definition \
  --desired-count 2 \
  --network-configuration "awsvpcConfiguration={subnets=[subnet-1,subnet-2],securityGroups=[sg-1],assignPublicIp=DISABLED}" \
  --load-balancers "targetGroupArn=target-group-arn,containerName=container-1,containerPort=80"

通过这种方式,您可以将流量路由到多个容器上的监听80端口,并且这些容器可以被发现。请确保在任务定义和目标组中正确配置容器端口和主机端口。

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...