forked from ShaoshiZ/PyHipp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
update_snapshot.sh
executable file
·54 lines (41 loc) · 1.92 KB
/
update_snapshot.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/bin/bash
# expects cluster-config.yaml to reside in ~/
# to be run outside the master node, before shutting down the cluster
# ~/cluster-config.yaml will be automatically repointed to the most updated snapshot
# pass unique description to identify all your snapshots as first argument
# pass the total number of snapshots (backups and current) to keep
# cluster identifier as optional 3rd argument
if [ "$#" -lt 2 ]
then
echo "insufficient arguments - description and number of snapshots to keep needed"
exit 1
fi
vol=$(aws ec2 describe-volumes --filter Name=attachment.device,Values=/dev/sdb Name=tag:aws:cloudformation:stack-name,Values=*$3* --query "Volumes[].VolumeId" --output text)
temp=($(aws ec2 create-snapshot --volume-id $vol --description "$1" --output text))
snap_in_prog=${temp[3]}
echo "new snapshot id: $snap_in_prog"
if [[ -z "${snap_in_prog// }" ]]; then
echo "ERROR: no snapshot found, invalid volume?"
exit 1
fi
keep=$2
all_snaps=($(aws ec2 describe-snapshots --owner self --filters Name=description,Values=$1 --query 'Snapshots[].[StartTime,SnapshotId]' --output text | sort -n | cut -f 2))
total_count=${#all_snaps[@]}
most_recent=${all_snaps[$total_count-1]}
if [ "$total_count" -ge "$(($keep+1))" ]
then
remove_snaps=(${all_snaps[@]:0:(($total_count-$keep))})
for snap in ${remove_snaps[@]}
do
aws ec2 delete-snapshot --snapshot-id $snap
done
fi
echo "keeping max $keep snapshots"
aws ec2 describe-snapshots --owner self --filters Name=description,Values=$1 --query 'Snapshots[].[StartTime,SnapshotId]' --output text | sort -n
cp ~/cluster-config.yaml ~/cluster-config.yaml.bak
sub_n=$(grep -n snap- ~/cluster-config.yaml | cut -d : -f 1)
head -$(($sub_n-1)) ~/cluster-config.yaml > ~/cluster-config.temp
echo " SnapshotId: $most_recent" >> ~/cluster-config.temp
tail -n +$(($sub_n+1)) ~/cluster-config.yaml >> ~/cluster-config.temp
mv ~/cluster-config.temp ~/cluster-config.yaml
echo "config file updated"