В моей учетной записи AWS тысячи снимков, которым исполнилось 12 месяцев. Поэтому приходится удалять снимки, которым 12 месяцев. Но проблема здесь в том, что мне нужно идентифицировать Сиротские Снимки (Не прикрепленные / созданные каким-либо AMI) и удалить их в первую очередь.
Пожалуйста, помогите мне добавить скрипт для определения снимков сирот, которым более 12 месяцев.
Пожалуйста, помогите мне со сценарием.
#!/bin/bash
set -e
AWS_ACCOUNT_ID=<ENTER_YOUR_ACCOUNT_ID_HERE>
REGION=us-west-2
ORPHANED_SNAPSHOTS_COUNT_LIMIT=10
WORK_DIR=/tmp
aws ec2 --region $REGION describe-snapshots --owner-ids $AWS_ACCOUNT_ID --query Snapshots[*].SnapshotId --output text | tr '\t' '\n' | sort > $WORK_DIR/all_snapshots
aws ec2 --region $REGION describe-images --filters Name=state,Values=available --owners $AWS_ACCOUNT_ID --query "Images[*].BlockDeviceMappings[*].Ebs.SnapshotId" --output text | tr '\t' '\n' | sort > $WORK_DIR/snapshots_attached_to_ami
ORPHANED_SNAPSHOT_IDS=`comm -23 <(sort $WORK_DIR/all_snapshots) <(sort $WORK_DIR/snapshots_attached_to_ami)`
if [ -z "$ORPHANED_SNAPSHOT_IDS" ]; then
echo "OK - no orphaned (not attached to any AMI) snapshots found"
exit 0
fi
ORPHANED_SNAPSHOT_IDS=`echo "$ORPHANED_SNAPSHOT_IDS" | grep "snap"`
ORPHANED_SNAPSHOTS_COUNT=`echo "$ORPHANED_SNAPSHOT_IDS" | wc -l`
if (( ORPHANED_SNAPSHOTS_COUNT > ORPHANED_SNAPSHOTS_COUNT_LIMIT )); then
echo "CRITICAL - $ORPHANED_SNAPSHOTS_COUNT orphaned (not attached to any AMI) snapshots found: [ $ORPHANED_SNAPSHOT_IDS ]"
echo "To delete them, use commands below:"
IFS=$'\n'
for snapshot_id in $ORPHANED_SNAPSHOT_IDS; do echo "aws ec2 --region us-west-2 delete-snapshot --snapshot-id $snapshot_id"; done
exit 1
else
echo "OK - $ORPHANED_SNAPSHOTS_COUNT orphaned (not attached to any AMI) snapshots found"
if (( ORPHANED_SNAPSHOTS_COUNT > 0 )); then
echo "[ $ORPHANED_SNAPSHOT_IDS ]"
fi
exit 0
fi