Skip to content

Commit

Permalink
Added wait condition until the node count equals the desired capacity.
Browse files Browse the repository at this point in the history
  • Loading branch information
simonzhekoff committed Dec 10, 2024
1 parent 59e2827 commit 1323a5b
Show file tree
Hide file tree
Showing 3 changed files with 74 additions and 6 deletions.
3 changes: 2 additions & 1 deletion modules/graphdb/main.tf
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ resource "aws_autoscaling_group" "graphdb_auto_scaling_group" {

instance_maintenance_policy {
min_healthy_percentage = var.instance_maintenance_policy_min_healthy_percentage
max_healthy_percentage = var.instance_maintenance_policy_min_healthy_percentage
max_healthy_percentage = var.instance_maintenance_policy_max_healthy_percentage
}

launch_template {
Expand Down Expand Up @@ -124,3 +124,4 @@ resource "aws_autoscaling_group" "graphdb_auto_scaling_group" {
}
}
}

73 changes: 70 additions & 3 deletions modules/graphdb/templates/00_functions.sh
Original file line number Diff line number Diff line change
@@ -1,12 +1,79 @@
#!/usr/bin/env bash

# Generic helper functions

# Function to print messages with timestamps
# Function to log messages with a timestamp
log_with_timestamp() {
echo "$(date '+%Y-%m-%d %H:%M:%S'): $1"
}

# Function to check ASG node counts
wait_for_asg_nodes() {
local ASG_NAME="$1"
local RETRY_DELAY=10
# Get the desired capacity of the ASG
local NODE_COUNT=$(aws autoscaling describe-auto-scaling-groups \
--auto-scaling-group-names "$ASG_NAME" \
--query "AutoScalingGroups[0].DesiredCapacity" \
--output text)

if [ "$NODE_COUNT" == "None" ]; then
log_with_timestamp "Error: Unable to retrieve Desired Capacity for ASG: $ASG_NAME."
exit 1
fi

log_with_timestamp "Checking ASG node count for $ASG_NAME with desired node count: $NODE_COUNT"

while true; do
# Check InService and Terminating states via ASG
local IN_SERVICE_NODE_COUNT
IN_SERVICE_NODE_COUNT=$(aws autoscaling describe-auto-scaling-groups \
--auto-scaling-group-names "$ASG_NAME" \
--query "AutoScalingGroups[0].Instances[?LifecycleState=='InService'] | length(@)" \
--output text)

local TERMINATING_NODE_COUNT
TERMINATING_NODE_COUNT=$(aws autoscaling describe-auto-scaling-groups \
--auto-scaling-group-names "$ASG_NAME" \
--query "AutoScalingGroups[0].Instances[?LifecycleState=='Terminating'] | length(@)" \
--output text)

# Check for instances in EC2 shutting-down state
local SHUTTING_DOWN_NODE_COUNT
SHUTTING_DOWN_NODE_COUNT=$(aws ec2 describe-instances \
--filters "Name=instance-state-name,Values=shutting-down" \
--query "Reservations[].Instances[].InstanceId | length(@)" \
--output text)

log_with_timestamp "InService: $IN_SERVICE_NODE_COUNT, Terminating: $TERMINATING_NODE_COUNT, Shutting-down: $SHUTTING_DOWN_NODE_COUNT, Desired: $NODE_COUNT"

if [[ -z "$IN_SERVICE_NODE_COUNT" || "$IN_SERVICE_NODE_COUNT" -le "$NODE_COUNT" ]] \
&& [[ "$TERMINATING_NODE_COUNT" -eq 0 ]] \
&& [[ "$SHUTTING_DOWN_NODE_COUNT" -eq 0 ]]; then
log_with_timestamp "Conditions met: InService <= $NODE_COUNT, no Terminating, no Shutting-down. Proceeding..."
break
else
log_with_timestamp "Conditions not met. Waiting... (InService: $IN_SERVICE_NODE_COUNT, Terminating: $TERMINATING_NODE_COUNT, Shutting-down: $SHUTTING_DOWN_NODE_COUNT)"
sleep "$RETRY_DELAY"
fi
done
}

# Wait for the desired nodes count
wait_desired_node_count() {
local ASG_NAME="$1"

if [ -z "$ASG_NAME" ]; then
log_with_timestamp "Error: ASG name not provided."
exit 1
fi

log_with_timestamp "Starting script execution for ASG: $ASG_NAME"
wait_for_asg_nodes "$ASG_NAME"
log_with_timestamp "Proceeding with the rest of the script after ASG check."
}

# Execute the main function with the provided ASG name
wait_desired_node_count "${name}"

# Function which waits for all DNS records to be created
wait_dns_records() {
local ZONE_ID="$1"
Expand Down
4 changes: 2 additions & 2 deletions modules/graphdb/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -398,11 +398,11 @@ variable "ebs_default_kms_key" {
variable "instance_maintenance_policy_min_healthy_percentage" {
description = "Define minimum healthy percentage for the Instance Maintenance Policy"
type = number
default = 100
default = 66
}

variable "instance_maintenance_policy_max_healthy_percentage" {
description = "Define maximum healthy percentage for the Instance Maintenance Policy"
type = number
default = 200
default = 100
}

0 comments on commit 1323a5b

Please sign in to comment.