登录
首页 >  Golang >  Go问答

如何获取与特定服务关联的任务 ID

来源:stackoverflow

时间:2024-04-12 13:15:35 393浏览 收藏

哈喽!今天心血来潮给大家带来了《如何获取与特定服务关联的任务 ID》,想必大家应该对Golang都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习Golang,千万别错过这篇文章~希望能帮助到你!

问题内容

当我调用 describeservies 时,我期待与我的服务关联的任务 arn 或任务 id 数组。但事实并非如此,除非我检查 events 对象:

events: [
        {
          createdat: 2020-07-03 03:57:56 +0000 utc,
          id: "af62a356-2ab7-4b18-b51c-718bef02901c",
          message: "(service 0271a020-aa1e-4b72-a57a-6d91c5f463e4) has reached a steady state."
        },
        {
          createdat: 2020-07-03 03:57:44 +0000 utc,
          id: "de2a4fad-8ea8-419d-8493-8c7cb5406afb",
          message: "(service 0271a020-aa1e-4b72-a57a-6d91c5f463e4) has stopped 1 running tasks: (task 1f92882b-72d0-490b-aa03-18fd32edb2e8)."
        },
        {
          createdat: 2020-07-03 01:35:09 +0000 utc,
          id: "bd8da7f5-9bb1-4d23-b416-f79678b487a8",
          message: "(service 0271a020-aa1e-4b72-a57a-6d91c5f463e4) has reached a steady state."
        },
        {
          createdat: 2020-07-03 01:34:40 +0000 utc,
          id: "da05f6a0-4163-4d93-b7af-22297d307620",
          message: "(service 0271a020-aa1e-4b72-a57a-6d91c5f463e4) has started 1 tasks: (task e132a2a7-ad49-4436-88cb-07b2ce399dd2)."
        },
        {
          createdat: 2020-07-02 14:29:21 +0000 utc,
          id: "cb56a4ff-de6a-402f-aaa5-377bf236b00a",
          message: "(service 0271a020-aa1e-4b72-a57a-6d91c5f463e4) has started 1 tasks: (task e69ca53b-7b5c-4c7d-aed2-b28d9261b111)."
        }
      ]

如您所见,提取任务 id 非常棘手

我的最终目标是以编程方式获取已部署服务的实例的 ip

我当前笨重的解决方案:(为简洁起见,省略了错误处理)

    servicesResponse, _ := s.ecsClient.DescribeServices(describeServicesParams)


    var taskId string
    for _, serviceEvent := range servicesResponse.Services[0].Events {

        if strings.Contains(*serviceEvent.Message, "has stopped 1 running tasks") {
            break
        }

        if strings.Contains(*serviceEvent.Message, "has started 1 tasks") {
            found := strings.Split(*serviceEvent.Message, "has started 1 tasks: (task ")[1]
            taskId = strings.Replace(found, ").", "", -1)
            break
        }
    }
    log.Info("taskId", taskId)


之后,我调用 describetasks 来获取 containerinstancearn,然后调用 describeinstances


解决方案


describetasks 正如您所指出的,它不太适合在服务中获取任务 id。

通常,要获取服务中的任务列表,您可以使用 ListTasks 调用。对于调用,您可以指定感兴趣的服务名称:

servicename:用于过滤 listtasks 结果的服务的名称。指定 servicename 将结果限制为属于该服务的任务

listtasks 将为您提供 taskarns,它又可用于 DescribeTasks 来获取任务 details

任务 id 是其 arn 的一部分,因此如果您只需要 id,可以从 arns 中提取它们。

这是基于 aws-cli 的工作示例,您可以根据所需的语言进行相应的转换。

  • 它获取服务的所有任务
  • 获取容器实例并陷阱 ec2_id
  • 获取ec2的ip 它会完全满足您的需求
#!/bin/bash
CLUSTER_NAME="mycluster"
SERVICE_NAME="app-service"
REGION="us-west-2"

echo "[INFO] Fetching tasks list for Cluster: $CLUSTER_NAME and Service: $SERVICE_NAME"
TASKS_ARN=($(aws ecs list-tasks --cluster $CLUSTER_NAME  --service $SERVICE_NAME --query 'taskArns[]' --output text))

for task in ${!TASKS_ARN[@]}; do
container_instances=$(aws ecs describe-tasks     --cluster $CLUSTER_NAME  --tasks ${TASKS_ARN[$task]} --query 'tasks[].containerInstanceArn' --output text)
ec2_instance_id=$(aws ecs describe-container-instances --cluster $CLUSTER_NAME --container-instances $container_instances --region $REGION --query 'containerInstances[*].ec2InstanceId' --output text)
ec2_ip=$(aws ec2 describe-instances --instance-id $ec2_instance_id --query 'Reservations[].Instances[].PublicIpAddress' --output text)
echo "[INFO] Task having ARN ${TASKS_ARN[$task]} runnng on EC2 machine having IP: $ec2_ip"
echo "[INFO] Fetchec completed  for task number $(($task+1)) out of ${#TASKS_ARN[@]},having Task ARN: ${TASKS_ARN[$task]}"
done

get_instance_ip_for_ecs_service.sh

以上就是《如何获取与特定服务关联的任务 ID》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>