131 lines
No EOL
6.2 KiB
HCL
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}"
|
|
}
|
|
} |