This repository was archived by the owner on Dec 19, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsnapshotRDSDatabase.sh
More file actions
executable file
·166 lines (150 loc) · 5.4 KB
/
snapshotRDSDatabase.sh
File metadata and controls
executable file
·166 lines (150 loc) · 5.4 KB
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
#!/bin/bash
trap 'find . -name STATUS.txt -exec rm {} \; ; exit $RESULT' EXIT SIGHUP SIGINT SIGTERM
DELAY_DEFAULT=30
TIER_DEFAULT="database"
function usage() {
echo -e "\nSnapshot an RDS Database"
echo -e "\nUsage: $(basename $0) -t TIER -i COMPONENT -s SUFFIX -c -m -d DELAY -r RETAIN -a AGE\n"
echo -e "\nwhere\n"
echo -e "(o) -a AGE is the maximum age in days of snapshots to retain"
echo -e "(o) -c (CREATE ONLY) initiates but does not monitor the snapshot creation process"
echo -e "(o) -d DELAY is the interval between checking the progress of snapshot creation. Default is ${DELAY_DEFAULT} seconds"
echo -e " -h shows this text"
echo -e "(m) -i COMPONENT is the name of the database component in the solution"
echo -e "(o) -m (MONITOR ONLY) monitors but does not initiate the snapshot creation process"
echo -e "(o) -r RETAIN is the count of snapshots to retain"
echo -e "(o) -s SUFFIX is appended to the snapshot identifier"
echo -e "(o) -t TIER is the name of the database tier in the solution. Default is \"${TIER_DEFAULT}\""
echo -e "\nNOTES:\n"
echo -e "1. Snapshot identifer takes the form {project}-{environment}-{tier}-{component}-datetime-{suffix}"
echo -e "2. RETAIN and AGE may be used together. If both are present, RETAIN is applied first"
echo -e ""
exit 1
}
DELAY=${DELAY_DEFAULT}
TIER=${TIER_DEFAULT}
CREATE=true
WAIT=true
# Parse options
while getopts ":a:cd:hi:mr:s:t:" opt; do
case $opt in
a)
AGE=$OPTARG
;;
c)
WAIT=false
;;
d)
DELAY=$OPTARG
;;
h)
usage
;;
i)
COMPONENT=$OPTARG
;;
m)
CREATE=false
;;
r)
RETAIN=$OPTARG
;;
s)
SUFFIX=$OPTARG
;;
t)
TIER=$OPTARG
;;
\?)
echo -e "\nInvalid option: -$OPTARG"
usage
;;
:)
echo -e "\nOption -$OPTARG requires an argument"
usage
;;
esac
done
# Ensure mandatory arguments have been provided
if [[ "${COMPONENT}" == "" ]]; then
echo -e "\nInsufficient arguments"
usage
fi
BIN="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
OAID="$(basename $(cd $BIN/../..;pwd))"
ROOT_DIR="$(cd $BIN/../..;pwd)"
# Determine the Organisation Account Identifier, Project Identifier, and region
# in which the stack should be created.
PID="$(basename $(cd ../;pwd))"
CONTAINER="$(basename $(pwd))"
if [[ -e 'container.json' ]]; then
REGION=$(grep '"Region"' container.json | cut -d '"' -f 4)
fi
if [[ "${REGION}" == "" && -e '../solution.json' ]]; then
REGION=$(grep '"Region"' ../solution.json | cut -d '"' -f 4)
fi
if [[ "${REGION}" == "" && -e '../../account.json' ]]; then
REGION=$(grep '"Region"' ../../account.json | cut -d '"' -f 4)
fi
if [[ "${REGION}" == "" ]]; then
echo -e "\nThe region must be defined in the container/solution/account configuration files (in this preference order). Nothing to do."
usage
fi
# Set the profile if on PC to pick up the IAM credentials to use to access the credentials bucket.
# For other platforms, assume the server has a service role providing access.
uname | grep -iE "MINGW64|Darwin|FreeBSD" > /dev/null 2>&1
if [[ "$?" -eq 0 ]]; then
PROFILE="--profile ${OAID}"
fi
DB_INSTANCE_IDENTIFIER="${PID}-${CONTAINER}-${TIER}-${COMPONENT}"
DB_SNAPSHOT_IDENTIFIER="${DB_INSTANCE_IDENTIFIER}-$(date -u +%Y-%m-%d-%H-%M-%S)"
if [[ "${SUFFIX}" != "" ]]; then
DB_SNAPSHOT_IDENTIFIER="${DB_SNAPSHOT_IDENTIFIER}-${SUFFIX}"
fi
if [[ "${CREATE}" == "true" ]]; then
aws ${PROFILE} --region ${REGION} rds create-db-snapshot --db-snapshot-identifier ${DB_SNAPSHOT_IDENTIFIER} --db-instance-identifier ${DB_INSTANCE_IDENTIFIER}
RESULT=$?
if [ "$RESULT" -ne 0 ]; then exit; fi
fi
if [[ ("${RETAIN}" != "") || ("${AGE}" != "") ]]; then
if [[ "${RETAIN}" != "" ]]; then
LIST=$(aws ${PROFILE} --region ${REGION} rds describe-db-snapshots --snapshot-type manual | grep DBSnapshotIdentifier | grep ${DB_INSTANCE_IDENTIFIER} | cut -d'"' -f 4 | sort | head -n -${RETAIN})
else
LIST=$(aws ${PROFILE} --region ${REGION} rds describe-db-snapshots --snapshot-type manual | grep DBSnapshotIdentifier | grep ${DB_INSTANCE_IDENTIFIER} | cut -d'"' -f 4 | sort)
fi
# echo LIST=$LIST
if [[ "${AGE}" != "" ]]; then
BASELIST=${LIST}
LIST=""
LASTDATE=$(date --utc +%Y%m%d%H%M%S -d "$AGE days ago")
for SNAPSHOT in $(echo $BASELIST); do
DATEPLUSSUFFIX=${SNAPSHOT#"$DB_INSTANCE_IDENTIFIER-"}
SUFFIX=${DATEPLUSSUFFIX#????-??-??-??-??-??}
SNAPSHOTDATE=$(echo ${DATEPLUSSUFFIX%"$SUFFIX"} | tr -d "-")
# echo LASTDATE=$LASTDATE, SNAPSHOT=$SNAPSHOTDATE
if [[ $LASTDATE > $SNAPSHOTDATE ]]; then
LIST="${LIST} ${SNAPSHOT}"
fi
done
fi
# echo LIST=$LIST
if [[ "${LIST}" != "" ]]; then
for SNAPSHOT in $(echo $LIST); do
aws ${PROFILE} --region ${REGION} rds delete-db-snapshot --db-snapshot-identifier $SNAPSHOT
done
fi
fi
RESULT=1
if [[ "${WAIT}" == "true" ]]; then
while true; do
aws ${PROFILE} --region ${REGION} rds describe-db-snapshots --db-snapshot-identifier ${DB_SNAPSHOT_IDENTIFIER} 2>/dev/null | grep "Status" > STATUS.txt
cat STATUS.txt
grep "available" STATUS.txt >/dev/null 2>&1
RESULT=$?
if [ "$RESULT" -eq 0 ]; then break; fi
grep "creating" STATUS.txt >/dev/null 2>&1
RESULT=$?
if [ "$RESULT" -ne 0 ]; then break; fi
sleep $DELAY
done
fi