2017-01-14 75 views
3

我正在尝试使用Terraform设置ECS群集,但我无法弄清楚如何在承载服务的ECS实例上使Terraform自动提供一个EBS卷,卷。如何将EBS卷添加到Terraform中的ECS实例

在我的配置我有:

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" 
    } 
] 

如何真正得到上承载该服务实例的音量?

回答

0

在Docker容器内部安装一个卷是其他配置EBS存储的其他内容。您复制了ECS服务/任务设置的配置,但未复制您的ECS实例(应该是正常的EC2实例)的设置。如果您使用标准ECS优化的Amazon Machine Image,则某些标准EBS卷会在安装时自动创建。

问题仍然存在,您希望在使用ECS时在Docker容器中安装卷。在很多情况下,这是不需要的和/或有其他更好的解决方案。 ECS构建的前提是任何容器都可以在群集中的任何实例上运行,如果您需要来自容器外部的特定数据,则此前提可能不成立。

相关问题