This workflow looks at all of the EC2 instances in a given account and region and selects a subset of those to terminate. The termination criteria are:
- Not tagged with a termination date or lifetime after 4 minutes
- The
termination_dateorlifetimetags are present but cannot be parsed - The
termination_dateorlifetimetags indicate that the instance has expired
An instance may be configured to never terminate if its lifetime tag has the
special value indefinite.
Before you run this workflow, you will need the following:
- An AWS account.
- An AWS IAM user with permissions to list and terminate EC2 instances (if not run in dry run mode).
- One or more running EC2 instances that are configured to use the
termination_dateorlifetimetags.
Follow these steps to run the workflow:
-
Add your AWS credentials as a Connection:
- Click Setup
- Find the Connection named
my-aws-accountand click Edit(✎). Use the following values:- KEY:
ACCESS KEY ID - VALUE: Enter your AWS access key id associated with the account
- KEY:
SECRET ACCESS KEY - VALUE: Enter your AWS secret access key associated with the account
- KEY:
- Click Save
-
Click Run workflow and wait for the workflow run page to appear.
-
Supply following parameters to the modal:
- KEY:
region - VALUE: The AWS region to run in
- KEY:
terminationDateTag - VALUE: The name of the tag to use for determining the termination date
- KEY:
lifetimeTag - VALUE: The name of the tag to use for determining the lifetime
- KEY:
dryRun - VALUE: True if you dont want to actually delete the resources. Use this to test the workflow and ensure it is behaving as expected.
- KEY:
-
Warning: If you run the workflow with the
dryRunparameter set tofalse, instances not in compliance with this workflow policy will immediately be terminated.
Follow these steps to run this workflow on a schedule:
- Un-comment out the Trigger block in the workflow file:
TIP: If you're using the Relay code editor, highlight the
triggerssection and type⌘ + /(Mac) orCtrl + /(Windows) to uncomment.
# triggers:
# - name: schedule
# source:
# type: schedule
# schedule: '0 * * * *'
# binding:
# parameters:
# region: us-east-1
# dryRun: true
# lifetimeTag: lifetime
# terminationDateTag: termination_date- Configure the
scheduletrigger:- Supply the run interval in cron format.
- Configure the following parameter bindings:
- Specify the
regionto run in. - Specify the
lifetimeTagto use. - Specify the
terminationDateTagto use. - Specify whether
dryRunshould be set totrueorfalse.
- Specify the
- Click Save changes