Skip to content

Latest commit

 

History

History
100 lines (83 loc) · 5.65 KB

File metadata and controls

100 lines (83 loc) · 5.65 KB

terraform-aws-ecs-cluster

A Terraform module to create an Amazon Web Services (AWS) EC2 Container Service (ECS) cluster. This module is an offshoot from this module where extra feature of enabling multiple types of instances in a cluster is enabled. This will allow the task to have more granular placement constraints.

NOTE

Please make sure you have the exact same size lists as that of the instance_types. If it's smaller than the instance_types list, you'll face errors.

Usage

data "template_file" "container_instance_cloud_config" {
  template = "${file("cloud-config/container-instance.yml.tpl")}"

  vars {
    environment = "${var.environment}"
  }
}

module "container_service_cluster" {
  source = "github.com/azavea/terraform-aws-ecs-cluster?ref=1.1.0"

  vpc_id        = "vpc-20f74844"
  ami_id        = "ami-b2df2ca4"
  instance_type = ["t2.micro", "m4.large"]
  key_name      = "hector"
  cloud_config_content  = "${data.template_file.container_instance_cloud_config.rendered}"

  root_block_device_type = ["gp2", "standard"]
  root_block_device_size = ["10", "50"]

  health_check_grace_period = "600"
  desired_capacity          = ["1", "2"]
  min_size                  = ["0", "0"]
  max_size                  = ["3", "4"]

  enabled_metrics = [
    "GroupMinSize",
    "GroupMaxSize",
    "GroupDesiredCapacity",
    "GroupInServiceInstances",
    "GroupPendingInstances",
    "GroupStandbyInstances",
    "GroupTerminatingInstances",
    "GroupTotalInstances",
  ]

  private_subnet_ids = [...]

  project     = "Something"
  environment = "Staging"
}

Variables

  • vpc_id - ID of VPC meant to house cluster
  • lookup_latest_ami - lookup the latest Amazon-owned ECS AMI. If this variable is true, the latest ECS AMI will be used, even if ami_id is provided (default: false).
  • ami_id - Cluster instance Amazon Machine Image (AMI) ID. If lookup_latest_ami is true, this variable will be silently ignored.
  • ami_owners - List of accounts that own the AMI (default: self, amazon, aws-marketplace)
  • root_block_device_type - Instance root block device type (default: gp2)
  • root_block_device_size - Instance root block device size in gigabytes (default: 8)
  • instance_types - Instance types for cluster instances (default: [t2.micro])
  • key_name - EC2 Key pair name
  • cloud_config_content - user data supplied to launch configuration for cluster nodes
  • cloud_config_content_type - the type of configuration being passed in as user data, see EC2 user guide for a list of possible types (default: text/cloud-config)
  • health_check_grace_period - Time in seconds after container instance comes into service before checking health (default: 600)
  • desired_capacity - Number of EC2 instances that should be running in cluster (default: 1)
  • min_size - Minimum number of EC2 instances in cluster (default: 0)
  • max_size - Maximum number of EC2 instances in cluster (default: 1)
  • enabled_metrics - A list of metrics to gather for the cluster
  • private_subnet_ids - A list of private subnet IDs to launch cluster instances
  • scale_up_cooldown_seconds - List for Number of seconds before allowing another scale up activity (default: [300])
  • scale_down_cooldown_seconds - List for Number of seconds before allowing another scale down activity (default: [300])
  • high_cpu_evaluation_periods - List for Number of evaluation periods for high CPU alarm (default: [2])
  • high_cpu_period_seconds - List for Number of seconds in an evaluation period for high CPU alarm (default: [300])
  • high_cpu_threshold_percent - Threshold as a percentage for high CPU alarm (default: [90])
  • low_cpu_evaluation_periods - List for Number of evaluation periods for low CPU alarm (default: [2])
  • low_cpu_period_seconds - List for Number of seconds in an evaluation period for low CPU alarm (default: [300])
  • low_cpu_threshold_percent - List for Threshold as a percentage for low CPU alarm (default: [10])
  • high_memory_evaluation_periods - List for Number of evaluation periods for high memory alarm (default: [2])
  • high_memory_period_seconds -List for Number of seconds in an evaluation period for high memory alarm (default: [300])
  • high_memory_threshold_percent - List for Threshold as a percentage for high memory alarm (default: [90])
  • low_memory_evaluation_periods - List for Number of evaluation periods for low memory alarm (default: [2])
  • low_memory_period_seconds - List for Number of seconds in an evaluation period for low memory alarm (default: [300])
  • low_memory_threshold_percent - List for Threshold as a percentage for low memory alarm (default: [10])
  • project - Name of project this cluster is for (default: Unknown)
  • environment - Name of environment this cluster is targeting (default: Unknown)
  • spot_enabled - Enabling AutoSpotting tag. It's the default tag used by AutoSpotting (default: true)

Outputs

  • id - The container service cluster ID
  • name - The container service cluster name
  • container_instance_security_group_id - Security group ID of the EC2 container instances
  • container_instance_ecs_for_ec2_service_role_name - Name of IAM role associated with EC2 container instances
  • ecs_service_role_name - Name of IAM role for use with ECS services
  • ecs_service_role_arn - ARN of IAM role for use with ECS services
  • container_instance_ecs_for_ec2_service_role_arn - ARN of IAM role associated with EC2 container instances
  • container_instance_autoscaling_group_name - Name of container instance Autoscaling Group