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

标签 amazon-web-services amazon-ec2 amazon-ecs terraform

我正在尝试使用 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/

相关文章:

amazon-web-services - 扫描 DynamoDB 中的关键属性

amazon-web-services - 同步两个 Amazon S3 存储桶的最快方法

amazon-web-services - ECS on EC2 同一任务中两个容器之间的双向通信

postgresql - 无法修改 Amazon RDS 上剩余连接槽的默认参数组

amazon-web-services - 使用 Cloudformation 在 `amplify push` 上拒绝 SQS API : sqs:CreateQueue Access to the resource https://sqs. us-east-1.amazonaws.com/

amazon-web-services - AWS DMS - 错误 - "AWS Account owning the Role must match the caller of the API"

r - pandoc 和 knitr 的 ssh 与 Rstudio 服务器中的路径

amazon-web-services - 实例附加了哪个角色

node.js - 如何从在 AWS ecs 上使用 docker 部署的应用程序获取日志

asp.net - Kestrel 对于在 ALB 后面的 AWS ECS 上运行的 ASP.NET Core 网站是否足够?