Amazon ECS 容器代理自检 - Amazon Elastic Container Service
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

Amazon ECS 容器代理自检

Amazon ECS 容器代理提供了一个 API 操作,用于收集有关正在运行该代理的容器实例以及在该实例上正在运行的相关任务的详细信息。您可以在容器实例内使用 curl 命令查询 Amazon ECS 容器代理(端口 51678)并返回容器实例元数据或任务信息。

重要

您的容器实例必须具有相应的 IAM 角色,以允许访问 Amazon ECS 来检索元数据。有关更多信息,请参阅Amazon ECS 容器实例 IAM 角色

要查看容器实例元数据,请通过 SSH 登录到容器实例并运行以下命令。元数据包含容器实例 ID、在其中注册容器实例的 Amazon ECS 集群和 Amazon ECS 容器代理版本信息。

curl -s http://localhost:51678/v1/metadata | python -mjson.tool

输出:

{
    "Cluster": "cluster_name",
    "ContainerInstanceArn": "arn:aws:ecs:region:aws_account_id:container-instance/cluster_name/container_instance_id",
    "Version": "Amazon ECS Agent - v1.30.0 (02ff320c)"
}

要查看有关在容器实例上运行的所有任务的信息,请通过 SSH 登录到容器实例并运行以下命令:

curl http://localhost:51678/v1/tasks

输出:

{
    "Tasks": [
        {
            "Arn": "arn:aws:ecs:us-west-2:012345678910:task/default/example5-58ff-46c9-ae05-543f8example",
            "DesiredStatus": "RUNNING",
            "KnownStatus": "RUNNING",
            "Family": "hello_world",
            "Version": "8",
            "Containers": [
                {
          "DockerId": "9581a69a761a557fbfce1d0f6745e4af5b9dbfb86b6b2c5c4df156f1a5932ff1",
          "DockerName": "ecs-hello_world-8-mysql-fcae8ac8f9f1d89d8301",
          "Name": "mysql",
          "CreatedAt": "2023-10-08T20:09:11.44527186Z",
          "StartedAt": "2023-10-08T20:09:11.44527186Z",
          "ImageID": "sha256:2ae34abc2ed0a22e280d17e13f9c01aaf725688b09b7a1525d1a2750e2c0d1de"
        },
        {
          "DockerId": "bf25c5c5b2d4dba68846c7236e75b6915e1e778d31611e3c6a06831e39814a15",
          "DockerName": "ecs-hello_world-8-wordpress-e8bfddf9b488dff36c00",
          "Name": "wordpress"
        }
    ]
}
    ]
}

您可以查看在容器实例上运行的特定任务的信息。要指定特定的任务或容器,请向请求中追加以下内容之一:

  • 任务 ARN (?taskarn=task_arn)

  • 容器的 Docker ID (?dockerid=docker_id)

要获取有关容器 Docker ID 的任务信息,请通过 SSH 登录到容器实例并运行以下命令。

注意

1.14.2 之前的 Amazon ECS 容器代理版本要求为自检 API 提供完整的 Docker 容器 ID,而不是利用 docker ps 显示的简略版。您可以通过在容器实例上运行 docker ps --no-trunc 命令来获取容器的完整 Docker ID。

curl http://localhost:51678/v1/tasks?dockerid=79c796ed2a7f

输出:

{
    "Arn": "arn:aws:ecs:us-west-2:012345678910:task/default/e01d58a8-151b-40e8-bc01-22647b9ecfec",
    "Containers": [
        {
            "DockerId": "79c796ed2a7f864f485c76f83f3165488097279d296a7c05bd5201a1c69b2920",
            "DockerName": "ecs-nginx-efs-2-nginx-9ac0808dd0afa495f001",
            "Name": "nginx",
            "CreatedAt": "2023-10-08T20:09:11.44527186Z",
            "StartedAt": "2023-10-08T20:09:11.44527186Z",
            "ImageID": "sha256:2ae34abc2ed0a22e280d17e13f9c01aaf725688b09b7a1525d1a2750e2c0d1de"
        }
    ],
    "DesiredStatus": "RUNNING",
    "Family": "nginx-efs",
    "KnownStatus": "RUNNING",
    "Version": "2"
}