created by tomfmason at 2008-12-08 13:25:15
A mysql binary backup script written in bash
 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
#!/usr/bin/env bash
#ported from http://dev.mysql.com/doc/refman/5.0/en/backup-policy.html (second comment)
#@author tomfmason@gmail.com

BINLOGPATH=/var/log/mysql
BINLOGNAME=mysql-bin
ARCHIVES=/var/backups/mysql
ARCHIVEPATH=$ARCHIVES/$(date +%Y-%m-%d)
mkdir -p $ARCHIVEPATH

function setReadable {
    chmod o+rx $BINLOGPATH
    chmod o+r $BINLOGPATH/*
}

function unsetReadable {
    chmod o-r $BINLOGPATH/*
    chmod o-rx $BINLOGPATH
}

function copyBinlogs {
    setReadable;
    for FILE in `cat $BINLOGPATH/$BINLOGNAME.index`; do
        if [ ! -f $ARCHIVEPATH/$FILE.gz ]; then
            cp $FILE $ARCHIVEPATH
            gzip $ARCHIVEPATH/$FILE
        fi
    done
    unsetReadable;
}

function flushLogs {
    mysqladmin -u root -p'password' flush-logs
    copyBinlogs;
}

function resetLogs {
    $YESTERDAY=$(date -d "yesterday" +%F)
    mysql -u root -p'password' -e "PURGE BINARY LOGS BEFORE '$YESTERDAY 23:59:58';"
}

function removeOldLogs {
    DATE=$(date -d "-3 days" +%F)
    if [ -d $ARCHIVES/$DATE ]; then
        rm -rf $ARCHIVES/$DATE
    fi
}

if [ $(date +%H) == "00" ]; then
    mysqladmin -u root -p'password' stop-slave
    copyBinlogs;
    flushLogs;
    resetLogs;
    mysqladmin -u root -p'password' start-slave
    removeOldLogs;
fi