]> arthur.barton.de Git - MkMySqlDump.git/blobdiff - bin/mkmysqldump
"--lock-all-tables" is implied by "--master-data"
[MkMySqlDump.git] / bin / mkmysqldump
index 64df8419d689c97e10a2e3bee9cf2e11e4bb5565..4093768d81b7064fdf9ac9460742c699ba6ed28a 100755 (executable)
@@ -24,6 +24,8 @@ Help() {
        echo "      MySQL server password [\"$MYPW\"]".
        echo "  --outfile|-o <file>"
        echo "      Path and name of SQL dump file [\"$OUTFILE\"]."
+       echo "  --outdir|-d <directory>"
+       echo "      Directory for automatically named dump files."
        echo "  --summary|-s"
        echo "      Display file and file system status summary."
        echo
@@ -63,6 +65,11 @@ while [ $# -gt 0 ]; do
                OUTFILE="$2"
                shift 2
                ;;
+         "--outdir"|"-d")
+               [ $# -ge 2 ] || Usage
+               OUTFILE="$2/$(hostname -s)-$(date "+%Y%m%d-%H%M%S").sql"
+               shift 2
+               ;;
          "--summary"|"-s")
                STATS=1
                shift
@@ -77,6 +84,7 @@ while [ $# -gt 0 ]; do
 done
 
 echo "Dumping MySQL server on \"$MYHOST\" (user \"$MYUSER\"):"
+echo "Started: $(date)"
 umask 0077
 
 [ -n "$MYPW" ] && PWSWITCH="--password='$MYPW'" || PWSWITCH=""
@@ -85,7 +93,9 @@ echo "Getting list of databases from server ..."
 DATABASES=$(
        mysql -h "$MYHOST" -u "$MYUSER" $PWSWITCH -e 'show databases' \
         | grep "^\| " | cut -d' ' -f2 | grep -v "Database" \
-        | grep -v "information_schema" | grep -v "mysql"
+        | grep -v "information_schema" \
+        | grep -v "performance_schema" \
+        | grep -v "mysql"
 )
 if [ $? -ne 0 ]; then
        echo "Failed to get list of databases! Aborting!"
@@ -97,20 +107,16 @@ CMD="mysqldump \
        -h $MYHOST \
        -u $MYUSER \
        $PWSWITCH \
-       --single-transaction \
+       --master-data=1 \
        --databases $DATABASES"
 
-echo "Start: $(date)"
+echo "Start date: $(date)"
 echo $CMD
 $CMD >"$OUTFILE"; r=$?
 echo "End: $(date)"
-
-[ $r -eq 0 ] \
-       && echo "Dump command exited with code 0, success." \
-       || echo "Dump command FAILED with code $r!" >&2
+echo
 
 if [ -e "$OUTFILE" -a -n "$STATS" ]; then
-       echo
        echo "SQL dump file"
        ls -lh "$OUTFILE"
        echo
@@ -118,4 +124,9 @@ if [ -e "$OUTFILE" -a -n "$STATS" ]; then
        echo
 fi
 
+[ $r -eq 0 ] \
+       && echo "Dump command exited with code 0, success." \
+       || echo "Dump command FAILED with code $r!" >&2
+
+echo
 exit $r