AWS zerstört automatisch EC2-Instanzen, die älter als X Tage sind

AWS zerstört automatisch EC2-Instanzen, die älter als X Tage sind

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 ###############")

verwandte Informationen