tileserver-gl/deployment/modules/tileserver/autoscaling.tf

131 lines
No EOL
6.2 KiB
HCL

resource "aws_launch_configuration" "launchconfiguration" {
name_prefix = "maps-${var.environment}-${var.version}-"
image_id = "${data.aws_ami.amazon_linux.id}"
key_name = "${data.terraform_remote_state.mono_keypair.key_name}"
iam_instance_profile = "${aws_iam_instance_profile.profile.name}"
security_groups = ["${aws_security_group.this.id}",
"${data.terraform_remote_state.mono_efs.ec2_security_group_id}"]
instance_type = "${var.instance_type}"
user_data = "${data.template_cloudinit_config.cloudinit.rendered}"
ebs_optimized = false
root_block_device {
delete_on_termination = true
volume_size = 50
}
lifecycle {
create_before_destroy = true
}
}
resource "aws_autoscaling_group" "autoscalinggroup" {
vpc_zone_identifier = ["${data.terraform_remote_state.mono_vpc.sn_private_a_id}"]
name = "${aws_launch_configuration.launchconfiguration.name}"
launch_configuration = "${aws_launch_configuration.launchconfiguration.name}"
max_size = 5
desired_capacity = 1
min_size = 1
health_check_grace_period = 300
health_check_type = "ELB"
force_delete = true
termination_policies = ["OldestInstance", "OldestLaunchConfiguration"]
target_group_arns = ["${aws_alb_target_group.target_group_this.arn}"]
enabled_metrics = ["GroupMinSize", "GroupMaxSize",
"GroupDesiredCapacity", "GroupInServiceInstances",
"GroupPendingInstances", "GroupStandbyInstances",
"GroupTerminatingInstances", "GroupTotalInstances"]
lifecycle {
create_before_destroy = true
}
tag {
key = "Name"
value = "maps"
propagate_at_launch = true
}
provisioner "local-exec" {
# Wait until the number of "ok" instance status checks is equal to 1
# command = "sleep 15;expected=2; current=0; retries=0; instances=$(aws autoscaling describe-auto-scaling-groups --auto-scaling-group-name \"${aws_autoscaling_group.autoscalinggroup.name}\" --query 'AutoScalingGroups[*].Instances[*].InstanceId' --output text); while [ \"$current\" -lt \"$expected\" ]; do for i in $(echo $instances); do check=$(aws elbv2 describe-target-health --target-group-arn \"${aws_alb_target_group.target_group_this.arn}\" --query \"TargetHealthDescriptions[?Target.Id == '$i'].TargetHealth.State\" --output text); echo \"$check\"; if [ \"$check\" = \"$(echo 'healthy')\" ]; then current=\"$(echo $((++current)))\"; else current=\"$(echo $((--current)))\"; fi; done; if [ \"$current\" -eq \"$expected\" ]; then break; else current=\"0\"; retries=\"$((++retries))\" fi; if [ \"$retries\" = \"3\" ]; then break;fi; done"
# command = "sleep 15;expected=2; current=0; retries=0; instances=$(aws autoscaling describe-auto-scaling-groups --auto-scaling-group-name \"${aws_autoscaling_group.autoscalinggroup.name}\" --query 'AutoScalingGroups[*].Instances[*].InstanceId' --output text); while [ \"$current\" -lt \"$expected\" ]; do for i in $(echo $instances); do check=$(aws elbv2 describe-target-health --target-group-arn \"${aws_alb_target_group.target_group_this.arn}\" --query \"TargetHealthDescriptions[?Target.Id == '$i'].TargetHealth.State\" --output text); echo \"$check\"; if [ \"$check\" = \"$(echo 'healthy')\" ]; then current=\"$(echo $((++current)))\"; else current=\"$(echo $((--current)))\"; fi; done; if [ \"$current\" -eq \"$expected\" ]; then break; else current=\"0\"; retries=\"$((++retries))\" fi; if [ \"$retries\" = \"3\" ]; then break;fi; done"
command = "sleep 15; instances=$(aws autoscaling describe-auto-scaling-groups --auto-scaling-group-name \"${aws_autoscaling_group.autoscalinggroup.name}\" --query 'AutoScalingGroups[*].Instances[*].InstanceId' --output text); for i in $(echo $instances); do while [ \"$(aws elbv2 describe-target-health --target-group-arn \"${aws_alb_target_group.target_group_this.arn}\" --query \"TargetHealthDescriptions[?Target.Id == '$i'].TargetHealth.State\" --output text)\" != \"healthy\"]; do echo \"Waiting for instance ${i} startup"; sleep 15; done; done; echo \"Waiting for final status check.\""
}
}
#
# Autoscaling policies
#
resource "aws_autoscaling_policy" "this-autoscale_group_policy_up_x1" {
name = "maps-autoscale_group_policy_up_x1"
scaling_adjustment = 1
adjustment_type = "ChangeInCapacity"
cooldown = 60
autoscaling_group_name = "${aws_autoscaling_group.autoscalinggroup.name}"
}
resource "aws_autoscaling_policy" "this-autoscale_group_policy_down_x1" {
name = "maps-autoscale_group_policy_down_x1"
scaling_adjustment = -1
adjustment_type = "ChangeInCapacity"
cooldown = 60
autoscaling_group_name = "${aws_autoscaling_group.autoscalinggroup.name}"
}
#
# ASG alarms
#
resource "aws_cloudwatch_metric_alarm" "this-cpu_high_alarm" {
alarm_name = "alarm-cpu-high-maps"
alarm_description = "This alarm triggers when CPU load in Autoscaling group is high."
metric_name = "CPUUtilization"
namespace = "AWS/EC2"
dimensions {
AutoScalingGroupName = "${aws_autoscaling_group.autoscalinggroup.name}"
}
statistic = "Average"
comparison_operator = "GreaterThanOrEqualToThreshold"
evaluation_periods = "1"
period = "60"
threshold = "70"
# Use autoscaling policy ARN as an alarm action here
# Reference: http://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html
alarm_actions = [
"${aws_autoscaling_policy.this-autoscale_group_policy_up_x1.arn}",
]
dimensions {
AutoScalingGroupName = "${aws_autoscaling_group.autoscalinggroup.name}"
}
}
resource "aws_cloudwatch_metric_alarm" "this-cpu_low_alarm" {
alarm_name = "alarm-cpu-low-maps"
alarm_description = "This alarm triggers when CPU load in Autoscaling group is low."
metric_name = "CPUUtilization"
namespace = "AWS/EC2"
dimensions {
AutoScalingGroupName = "${aws_autoscaling_group.autoscalinggroup.name}"
}
statistic = "Average"
comparison_operator = "LessThanOrEqualToThreshold"
evaluation_periods = "1"
period = "60"
threshold = "35"
# Use autoscaling policy ARN as an alarm action here
# Reference: http://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html
alarm_actions = [
"${aws_autoscaling_policy.this-autoscale_group_policy_down_x1.arn}",
]
dimensions {
AutoScalingGroupName = "${aws_autoscaling_group.autoscalinggroup.name}"
}
}