Контроллер запланированных задач ECS переопределений для entryPoint не работает - PullRequest
0 голосов
/ 11 апреля 2019

Я создаю запланированное задание ECS в Terraform. Когда я пытаюсь переопределить определение контейнера для entryPoint, результирующая задача не использует переопределенный entryPoint. Однако, если я пытаюсь переопределить command, он работает нормально (добавляет новую команду в дополнение к существующей точке входа). Я не могу найти в документах ничего, что могло бы заставить меня поверить, что нет поддержки для entryPoint переопределения, но это может быть так?

Ниже приведен код для цели события Cloudwatch в terraform

resource "aws_cloudwatch_event_target" "ecs_task" {
  target_id = "run-${var.task_name}-scheduled"
  arn       = "${var.cluster_arn}"
  rule      = "${aws_cloudwatch_event_rule.ecs_task_event_rule.name}"
  role_arn  = "${aws_iam_role.ecs_event.arn}"

  ecs_target = {
    launch_type = "${var.launch_type}"
    network_configuration = {
      subnets = ["${var.subnet_ids}"]
      security_groups = ["${var.security_group_ids}"]
    }
    task_count = 1
    task_definition_arn = "${var.task_arn}"
  }

  input = <<DOC
{
  "containerOverrides": [
    {
      "name": "${var.task_name}",
      "entryPoint": ${jsonencode(var.command_overrides)}
    }
  ]
}
DOC
}

Это создает новую запланированную задачу на консоли AWS, где поле ввода имеет следующий вид:

{
    "containerOverrides": [
        {
            "name": "my-container-name",
            "entryPoint": [
                "sh",
                "/my_script.sh"
            ]
        }
    ]
}

Однако задачи, запускаемые этим правилом, не имеют переопределения точки входа и используют точку входа, определенную в исходном определении задачи.

TLDR : Как переопределить точку входа для запланированного задания?

1 Ответ

0 голосов
/ 11 апреля 2019

На сегодняшний день только определенное количество полей может быть переопределено, так как запланированная задача в конечном итоге использует run-task API. Эти поля следующие:

  • command
  • environment
  • taskRoleArn
  • cpu
  • memory
  • memoryReservation
  • resourceRequirements

Определения контейнеров для других полей не поддерживаются, например entryPoint, portMappings и logConfiguration.

Решение состоит в том, чтобы использовать command вместо entryPoint в исходном определении задачи, поскольку command может быть переопределено, но entryPoint не может.

...