in playbooks/active_instances_in_asg.py [0:0]
def run(self,asg_name):
session = botocore.session.Session(profile=self.profile)
asg = session.create_client('autoscaling',self.region)
ec2 = session.create_client('ec2',self.region)
groups = asg.describe_auto_scaling_groups()
matching_groups = [g for g in groups['AutoScalingGroups'] for t in g['Tags'] if t['Key'] == 'Name' and t['Value'] == asg_name]
groups_to_instances = {group['AutoScalingGroupName']: [instance['InstanceId'] for instance in group['Instances']] for group in matching_groups}
instances_to_groups = {instance['InstanceId']: group['AutoScalingGroupName'] for group in matching_groups for instance in group['Instances'] }
# We only need to check for ASGs in an ELB if we have more than 1.
# If a cluster is running with an ASG out of the ELB, then there are larger problems.
active_groups = defaultdict(dict)
if len(matching_groups) > 1:
elb = session.create_client('elb',self.region)
for group in matching_groups:
for load_balancer_name in group['LoadBalancerNames']:
instances = elb.describe_instance_health(LoadBalancerName=load_balancer_name)
active_instances = [instance['InstanceId'] for instance in instances['InstanceStates'] if instance['State'] == 'InService']
for instance_id in active_instances:
active_groups[instances_to_groups[instance_id]] = 1
if len(active_groups) > 1:
# When we have more than a single active ASG, we need to bail out as we don't know what ASG to pick an instance from
print("Multiple active ASGs - unable to choose an instance", file=sys.stderr)
return
else:
active_groups = { g['AutoScalingGroupName']: 1 for g in matching_groups }
for group in active_groups.keys():
for group_instance in groups_to_instances[group]:
instance = ec2.describe_instances(InstanceIds=[group_instance])['Reservations'][0]['Instances'][0]
if 'PrivateIpAddress' in instance:
print("{},".format(instance['PrivateIpAddress']))
return # We only want a single IP