Skip to content
Snippets Groups Projects
ecs.tf 2.25 KiB
Newer Older
  template = file("./templates/container-definitions.tpl")
    container_name          = var.container_name
    image_name              = var.image_name
    app_port1               = var.container_app_port[0]
    app_port2               = var.container_app_port[1]
    app_port3               = var.container_app_port[2]
    informatica_username    = var.informatica_username
    informatica_password    = var.informatica_password
    volume1                 = var.secure_agnet_container_volumes[0]
    volume2                 = var.secure_agnet_container_volumes[1]
    volume3                 = var.secure_agnet_container_volumes[2]
    volume4                 = var.secure_agnet_container_volumes[3]
    secure_agent_efs_volume = var.secure_agent_efs_volume
  }
}

data "aws_iam_role" "ecs-task-execution" {
  name = "ecsTaskExecutionRole"
}

resource "aws_ecs_task_definition" "task" {
  family                   = var.ecs_task_name
  execution_role_arn       = data.aws_iam_role.ecs-task-execution.arn
  network_mode             = var.container_network_mode
  requires_compatibilities = [
  container_definitions    = data.template_file.container.rendered
  volume {
    name      = var.secure_agent_efs_volume
    host_path = ""
    docker_volume_configuration {
      autoprovision = true
      scope         = "shared"

      driver_opts = {
        "type"   = "nfs"
        "device" = "${aws_efs_file_system.secure-agent-fs.dns_name}:/"
        "o"      = "addr=${aws_efs_file_system.secure-agent-fs.dns_name},nfsvers=4.1,rsize=1048576,wsize=1048576,hard,timeo=600,retrans=2,nosuid"
      }
    }
  }
  tags                     = var.ecs_task_tags
  name            = var.ecs_service_name
  cluster         = aws_ecs_cluster.cluster.id
  task_definition = aws_ecs_task_definition.task.arn
  # secure agent configs and logs are persisted into an EFS volume.
  launch_type     = "EC2"
    security_groups  = [
      data.aws_security_group.sec-group.id]
    subnets          = data.aws_subnet_ids.subnets.ids
    assign_public_ip = false
  }
}

resource "aws_ecs_cluster" "cluster" {
  name = var.ecs_cluster_name
  tags = var.ecs_cluster_tags
}