Implemented Auto Scaling groups recreate terminated instances.
This commit is contained in:
parent
201d9fb491
commit
19c9c59367
@ -684,6 +684,18 @@ class AutoScalingBackend(BaseBackend):
|
|||||||
for instance in protected_instances:
|
for instance in protected_instances:
|
||||||
instance.protected_from_scale_in = protected_from_scale_in
|
instance.protected_from_scale_in = protected_from_scale_in
|
||||||
|
|
||||||
|
def notify_terminate_instances(self, instance_ids):
|
||||||
|
for autoscaling_group_name, autoscaling_group in self.autoscaling_groups.items():
|
||||||
|
original_instance_count = len(autoscaling_group.instance_states)
|
||||||
|
autoscaling_group.instance_states = list(filter(
|
||||||
|
lambda i_state: i_state.instance.id not in instance_ids,
|
||||||
|
autoscaling_group.instance_states
|
||||||
|
))
|
||||||
|
difference = original_instance_count - len(autoscaling_group.instance_states)
|
||||||
|
if difference > 0:
|
||||||
|
autoscaling_group.replace_autoscaling_group_instances(difference, autoscaling_group.get_propagated_tags())
|
||||||
|
self.update_attached_elbs(autoscaling_group_name)
|
||||||
|
|
||||||
|
|
||||||
autoscaling_backends = {}
|
autoscaling_backends = {}
|
||||||
for region, ec2_backend in ec2_backends.items():
|
for region, ec2_backend in ec2_backends.items():
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
from boto.ec2.instancetype import InstanceType
|
from boto.ec2.instancetype import InstanceType
|
||||||
|
|
||||||
|
from moto.autoscaling import autoscaling_backends
|
||||||
from moto.core.responses import BaseResponse
|
from moto.core.responses import BaseResponse
|
||||||
from moto.core.utils import camelcase_to_underscores
|
from moto.core.utils import camelcase_to_underscores
|
||||||
from moto.ec2.utils import filters_from_querystring, \
|
from moto.ec2.utils import filters_from_querystring, \
|
||||||
@ -64,6 +66,7 @@ class InstanceResponse(BaseResponse):
|
|||||||
instance_ids = self._get_multi_param('InstanceId')
|
instance_ids = self._get_multi_param('InstanceId')
|
||||||
if self.is_not_dryrun('TerminateInstance'):
|
if self.is_not_dryrun('TerminateInstance'):
|
||||||
instances = self.ec2_backend.terminate_instances(instance_ids)
|
instances = self.ec2_backend.terminate_instances(instance_ids)
|
||||||
|
autoscaling_backends[self.region].notify_terminate_instances(instance_ids)
|
||||||
template = self.response_template(EC2_TERMINATE_INSTANCES)
|
template = self.response_template(EC2_TERMINATE_INSTANCES)
|
||||||
return template.render(instances=instances)
|
return template.render(instances=instances)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user