gpt4 book ai didi

amazon-web-services - 如何在 Terraform 中将 EBS 卷添加到 ECS 实例

转载 作者:行者123 更新时间:2023-12-04 08:16:46 25 4
gpt4 key购买 nike

我正在尝试使用 Terraform 设置 ECS 集群,但我不知道如何在托管需要该卷的服务的 ECS 实例上使 Terraform 自动配置一个 EBS 卷。

在我的配置中,我有:

resource "aws_ecs_task_definition" "name" {
family = "name"
container_definitions = "${file("task-definitions/name.json")}"

volume {
name = "name-storage"
host_path = "/ecs/name-storage"
}
}

resource "aws_ecs_service" "name" {
name = "name"
cluster = "${aws_ecs_cluster.main.id}"
task_definition = "${aws_ecs_task_definition.name.arn}"
desired_count = 1
iam_role = "${aws_iam_role.ecs_service_role.arn}"
depends_on = ["aws_iam_role_policy.ecs_service_role_policy"]

load_balancer {
elb_name = "${aws_elb.name.id}"
container_name = "name"
container_port = 8000
}
}

并在 task-definitions/name.json我有:
"mountPoints": [
{
"sourceVolume": "name-storage",
"containerPath": "/var/lib/cassandra"
}
]

我如何实际获取托管此服务的实例上的卷?

最佳答案

在 Docker 容器内挂载卷与配置 EBS 存储不同。您复制了 ECS 服务/任务设置的配置,但未复制 ECS 实例(应该是普通 EC2 实例)的设置。如果您使用标准 ECS 优化的 Amazon 系统镜像,则会在设置时自动创建一些标准 EBS 卷。
问题仍然是您是否想在使用 ECS 时在 Docker 容器内安装卷。在很多情况下,这不是必需的和/或有其他更好的解决方案。 ECS 的构建前提是任何容器都可以在集群中的任何实例上运行,如果您需要来自容器外部的特定数据,这个前提可能不成立。

关于amazon-web-services - 如何在 Terraform 中将 EBS 卷添加到 ECS 实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41648046/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com