Add 'extended.sh'
This commit is contained in:
57
extended.sh
Normal file
57
extended.sh
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
##################################
|
||||||
|
#
|
||||||
|
# Installation
|
||||||
|
#
|
||||||
|
# 0. Place this script in /usr/local/sbin with 700 rights
|
||||||
|
# 1. Create a user in MySQL with SELECT, RELOAD and LOCK TABLES on all databases.
|
||||||
|
# 2. fill in the username and password of the mysql account below
|
||||||
|
# 3. create the directory /var/myexport
|
||||||
|
# 4. crontab this script to run 3 times a day
|
||||||
|
#
|
||||||
|
#################################
|
||||||
|
|
||||||
|
USER=<user>
|
||||||
|
#PASS=<pass>
|
||||||
|
COPIES=2
|
||||||
|
BASE=<path>
|
||||||
|
|
||||||
|
if [ ! -d $BASE ]
|
||||||
|
then
|
||||||
|
echo "Backup share not available, stopping"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ $# -gt 0 ]; then
|
||||||
|
DBLIST="$*"
|
||||||
|
else
|
||||||
|
#DBLIST=`mysql -u $USER --password=$PASS -s -e 'show databases'`
|
||||||
|
DBLIST=`mysql -u $USER -s -e 'show databases'`
|
||||||
|
fi
|
||||||
|
|
||||||
|
for N in $DBLIST;
|
||||||
|
do
|
||||||
|
case $N in
|
||||||
|
"Database")
|
||||||
|
echo "ignoring Database"
|
||||||
|
;;
|
||||||
|
"information_schema")
|
||||||
|
echo "ignoring Information_Schema"
|
||||||
|
;;
|
||||||
|
"performance_schema")
|
||||||
|
echo "ignoring Performance_schema"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "dumping $N"
|
||||||
|
i=$(($COPIES - 1))
|
||||||
|
while [ $i -ge 0 ];
|
||||||
|
do
|
||||||
|
[ -s $BASE/$N.sql.$i.gz ] && mv $BASE/$N.sql.$i.gz $BASE/$N.sql.$(($i+1)).gz
|
||||||
|
i=$(($i-1))
|
||||||
|
done
|
||||||
|
#mysqldump -u $USER --opt --password=$PASS $N | gzip >$BASE/$N.sql.0.gz
|
||||||
|
mysqldump -u $USER --opt $N | gzip >$BASE/$N.sql.0.gz
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
Reference in New Issue
Block a user