我正在 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
}
这会在 AWS 控制台上创建一个新的计划任务,其中输入字段如下:
{
"containerOverrides": [
{
"name": "my-container-name",
"entryPoint": [
"sh",
"/my_script.sh"
]
}
]
}
但是,此规则启动的任务没有入口点覆盖,而是使用原始任务定义中定义的入口点。
TLDR:如何覆盖计划任务的入口点?
截至今天,只有一定数量的字段可以被覆盖,因为计划任务最终使用 run-task
API。这些字段如下:
-
command
-
environment
-
taskRoleArn
-
cpu
-
memory
-
memoryReservation
-
resourceRequirements
不支持其他字段的容器定义,例如 entryPoint
、 portMappings
和 logConfiguration
。
解决方案是在原始任务定义中使用command
而不是entryPoint
,因为可以覆盖command
,但不能覆盖entryPoint
。