
Wir erstellen automatisch EC2-Instanzen als ReviewApps. Die Prüfer sollen die EC2-Instanzen zerstören, aber das passiert nicht immer.
Ich möchte also ein Skript (Lambda, Terraform usw.?) erstellen, das EC2-Instanzen für diesen bestimmten AWS-Benutzer nach X Tagen automatisch zerstört. Gibt es bekannte Ausführungen?
Antwort1
Habe es jetzt mit folgendem Code zum Laufen gebracht:
#!/usr/bin/env python3
import boto3
import datetime
from botocore.config import Config
print ("############### EC2 Cleanup Start ###############")
my_config = Config(
region_name = 'eu-central-1',
)
ec2 = boto3.resource('ec2', config=my_config)
# Delete AWS instances older than 14 days
date_filter = (datetime.datetime.now() - datetime.timedelta(days=14)).strftime("%Y-%m-%d")
instances = ec2.instances.filter(Filters=[
{'Name':'launch-time', 'Values':[date_filter+'*']},
{'Name':'tag-value', 'Values':['review-app-*']}
])
for instance in instances:
print(instance.id, instance.terminate())
print ("############### EC2 Cleanup Done ###############")