-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathget-rds-log.sh
executable file
·43 lines (31 loc) · 1.16 KB
/
get-rds-log.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
#!/usr/bin/env bash
DB_NAME=${1:-production-pgsql}
FILE=${2:-postgresql.log.$(date +%F-%H --date "1 hour ago")}
OUTPUT_DIR=${3:-error}
COUNTER=1
LASTFOUNDTOKEN=0
PREVIOUSTOKEN=0
rm -f ${FILE}
while [ $COUNTER -lt 100 ]; do
echo "Lets try and get ${FILE}.${COUNTER}"
echo "The starting-token will be set to ${LASTFOUNDTOKEN}"
PREVIOUSTOKEN=${LASTFOUNDTOKEN}
aws rds download-db-log-file-portion --db-instance-identifier ${DB_NAME} --log-file-name error/${FILE} --starting-token ${LASTFOUNDTOKEN} --debug --output text 2>>${FILE}.${COUNTER}.debug >> ${FILE}.${COUNTER}
LASTFOUNDTOKEN=`grep "<Marker>" ${FILE}.${COUNTER}.debug | tail -1 | tr -d "<Marker>" | tr -d "/" | tr -d " "`
echo "LASTFOUNDTOKEN is ${LASTFOUNDTOKEN}"
echo "PREVIOUSTOKEN is ${PREVIOUSTOKEN}"
if [ ${PREVIOUSTOKEN} == ${LASTFOUNDTOKEN} ]; then
echo "No more new markers, exiting"
rm -f ${FILE}.${COUNTER}.debug
rm -f ${FILE}.${COUNTER}
exit;
else
echo "Marker is ${LASTFOUNDTOKEN} more to come ... "
echo " "
rm -f ${FILE}.${COUNTER}.debug
PREVIOUSTOKEN=${LASTFOUNDTOKEN}
fi
cat ${FILE}.${COUNTER} >> ${OUTPUT_DIR}/${FILE}
rm -f ${FILE}.${COUNTER}
let COUNTER=COUNTER+1
done