tileserver-gl/deployment/modules/tileserver/autoscaling.tf
2019-06-24 20:26:25 +02:00

158 lines
No EOL
5 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" -eq "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" -eq "3" ]]; then \
break;\
fi
done
"
}
}
#
# 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}"
}
}