-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsql-to-s3.sh
More file actions
51 lines (44 loc) · 1.41 KB
/
sql-to-s3.sh
File metadata and controls
51 lines (44 loc) · 1.41 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
#!/bin/bash
# general script to dump SQL results,
# transform into CSV and move copy to S3
PROG=$(basename $0)
PROG=`echo $PROG| awk -F. '{ print $1 }'`
NOW=`date +%s`
POSTGRES_USER="##POSTGRES_USER##"
POSTGRES_PASS="##POSTGRES_PASSWORD##"
POSTGRES_HOST="##POSTGRES_HOST##"
POSTGRES_PORT=5432
MYSQL_USER="##MYSQL_USER##"
MYSQL_PASS="##MYSQL_PASSWORD##"
MYSQL_HOST="##MYSQL_HOST##"
# Define usage information
USAGE="Usage: ./$PROG.sh [-h <host>] [-d <db>] [-s <sql file to run>] [-p <aws profile>] [-b <full path to s3 bucket> ]"
# Parse the command line arguments:
while getopts h:d:s:b:p: c ; do
case $c in
h) HOST="${OPTARG}" ;;
d) DB="${OPTARG}" ;;
s) SQL="${OPTARG}" ;;
b) BUCKET="${OPTARG}" ;;
p) PROFILE="${OPTARG}" ;;
*) echo "$USAGE" ; exit 2 ;;
esac
done
if [ -z $HOST ] || [ -z $DB ] || [ -z $SQL ] || [ -z $BUCKET ] || [ -z $PROFILE ]; then
echo -e $USAGE;
exit;
else
OUTFILE=$SQL-$NOW.csv
if [ "$HOST" = "postgres" ]; then
PGPASSWORD=$POSTGRES_PASS psql -h $POSTGRES_HOST -U $POSTGRES_USER -d $DB -p $POSTGRES_PORT -A -t -F',' -f $SQL -o $OUTFILE
elif [ "$HOST" = "mysql" ]; then
mysql -u$MYSQL_USER -h$MYSQL_HOST -p -A $DB < $SQL | sed 's/\t/,/g;s/\n//g' > $OUTFILE
else
echo "Unknown host: $HOST"
fi
if [ -f $OUTFILE ]; then
# copy to s3
aws --profile=$PROFILE s3 cp $OUTFILE $BUCKET
rm -f $OUTFILE
fi
fi