如何从 ECS 容器中获取任务 ID?

Posted

技术标签:

【中文标题】如何从 ECS 容器中获取任务 ID?【英文标题】:How to get Task ID from within ECS container? 【发布时间】:2018-07-26 22:50:34 【问题描述】:

您好,我有兴趣从位于 EC2 主机内部的正在运行的容器中检索 Task ID

AWS ECS documentation 声明有一个环境变量 ECS_CONTAINER_METADATA_FILE 包含此数据的位置,但只有在创建集群/EC2 实例时将 ECS_ENABLE_CONTAINER_METADATA 变量设置为 true 时才会设置/可用。我看不到可以在 aws 控制台中的哪个位置完成此操作。

此外,文档指出,这可以通过在主机内将其设置为 true 来完成,但需要重新启动 docker 代理。

有没有其他方法可以做到这一点,而无需进入 EC2 内部进行设置并重新启动 docker 代理?

【问题讨论】:

【参考方案1】:

From the AWS ECS cli Documentation

命令:

aws ecs list-tasks --cluster default

输出:


    "taskArns": [
        "arn:aws:ecs:us-east-1:<aws_account_id>:task/0cc43cdb-3bee-4407-9c26-c0e6ea5bee84",
        "arn:aws:ecs:us-east-1:<aws_account_id>:task/6b809ef6-c67e-4467-921f-ee261c15a0a1"
    ]

列出特定容器实例上的任务

此示例命令列出指定容器实例的任务,使用容器实例 UUID 作为过滤器。

命令:

aws ecs list-tasks --cluster default --container-instance f6bbb147-5370-4ace-8c73-c7181ded911f

输出:


    "taskArns": [
        "arn:aws:ecs:us-east-1:<aws_account_id>:task/0cc43cdb-3bee-4407-9c26-c0e6ea5bee84"
    ]

【讨论】:

【参考方案2】:

我使用的技术是在容器定义中设置环境变量。

如果您正在管理您的任务via Cloudformation,则相关的 yaml 如下所示:

  Taskdef:
    Type: AWS::ECS::TaskDefinition
    Properties:
      ...
      ContainerDefinitions:
        - Name: some-name
          ...
          Environment:
            - Name: AWS_DEFAULT_REGION
              Value: !Ref AWS::Region
            - Name: ECS_ENABLE_CONTAINER_METADATA
              Value: 'true'

此技术可帮助您保持一切简单且可重复。

如果您以编程方式需要元数据并且无权访问元数据文件,您可以查询the agent's metadata endpoint:

curl http://localhost:51678/v1/metadata

请注意,如果您将此信息作为正在运行的任务获取,您可能无法连接到环回设备,但您可以连接到 EC2 实例自己的 IP 地址。

【讨论】:

【参考方案3】:

我们使用所谓的用户数据设置它,这些数据在机器启动时执行。有多种设置方式,例如:https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/user-data.html#user-data-console

它可能看起来像这样:

#!/bin/bash

cat <<'EOF' >> /etc/ecs/ecs.config
ECS_CLUSTER=ecs-staging
ECS_ENABLE_CONTAINER_METADATA=true
EOF

重要提示:调整上面的ECS_CLUSTER 以匹配您的集群名称,否则实例将无法连接到该集群。

【讨论】:

【参考方案4】:

以前的答案是正确的,这是另一种方法:

从运行容器的 ec2 实例中,运行此命令

curl http://localhost:51678/v1/tasks | python -mjson.tool |less

【讨论】:

【参考方案5】:

这不再适用于较新的 Amazon ECS 容器版本,事实上它现在更简单并且默认启用。请参考this docu,但这里有一个TL;DR

如果您使用的是 Amazon ECS 容器代理版本 1.39.0 及更高版本,您可以在 docker 容器内执行此操作:

curl -s "$ECS_CONTAINER_METADATA_URI_V4/task" \
  | jq -r ".TaskARN" \
  | cut -d "/" -f 3

这是container agent releases 的列表,但如果您使用的是:latest – 肯定没问题。

【讨论】:

以上是关于如何从 ECS 容器中获取任务 ID?的主要内容,如果未能解决你的问题,请参考以下文章

获取从 aws cli 运行的 ecs 任务的外部链接

如何在 AWS ECS 中扩展任务/容器

如何从运行 Fargate ECS 任务中查看 Python 打印语句?

如何链接在 AWS ECS 任务中运行的 2 个容器

aws 如何从生产环境中的 lambda 函数访问 ECS 服务

如何从 ECS 任务中安装 aws cli?