tileserver-gl/deployment/modules/tileserver/autoscaling.tf
2019-04-24 11:17:56 +02:00

124 lines
No EOL
3.9 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 = "maps-${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
}
}
#
# 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}"
}
}