ECS计划任务containerOverrides的entryPoint不起作用

wil*_*fry 4 amazon-ecs amazon-cloudwatch terraform-provider-aws

我正在 Terraform 中创建计划的 ECS 任务。当我尝试覆盖 的容器定义时entryPoint,生成的任务不使用覆盖的entryPoint. 但是,如果我尝试覆盖command,它可以正常工作(除了现有入口点之外还添加一个新命令)。我在文档中找不到任何让我相信不支持entryPoint重写的内容,但情况可能是这样?

以下是 terraform 中 Cloudwatch 事件目标的代码

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
}
Run Code Online (Sandbox Code Playgroud)

这将在 AWS 控制台上创建一个新的计划任务,其中输入字段如下:

{
    "containerOverrides": [
        {
            "name": "my-container-name",
            "entryPoint": [
                "sh",
                "/my_script.sh"
            ]
        }
    ]
}
Run Code Online (Sandbox Code Playgroud)

但是,由此规则启动的任务没有入口点覆盖,而是使用原始任务定义中定义的入口点。

TLDR:如何覆盖计划任务的入口点?

wil*_*fry 5

截至目前,由于计划任务最终使用 API,因此只能覆盖一定数量的字段run-task。这些字段如下:

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

不支持其他字段的容器定义,例如entryPointportMappingslogConfiguration

解决办法是在原来的任务定义中使用command而不是,因为可以被覆盖但不能。entryPointcommandentryPoint