mysql全庫備份/增量備份腳本

http://hongge.blog.51cto.com/mysql

生產環境中Mysql數據庫的備份是週期性重複的操做,因此一般是要編寫腳本實現,經過crond計劃任務週期性執行備份腳本sql

mysqldump備份方案:數據庫

週日凌晨1點全庫備份dom

週一到週六凌晨每隔4個小時增量備份一次ide

設置crontab任務,天天執行備份腳本日誌

# crontab –eblog

#每一個星期日凌晨1:00執行徹底備份腳本crontab

0 1 * * 0 /root/mysqlfullbackup.sh >/dev/null 2>&1ip

#週一到週六每隔4個小時增量備份一次get

0 */4 * * 1-6 /root/mysqldailybackup.sh >/dev/null 2>&1

mysqlfullbackup.sh腳本內容:

[root@localhost ~]# cat mysqlfullbackup.sh

#!/bin/sh

# Name:mysqlFullBackup.sh

# 定義數據庫目錄

mysqlDir=/usr/local/mysql

# 定義用於備份數據庫的用戶名和密碼

user=root

userpwd=123456

dbname=test_db

# 定義備份目錄

databackupdir=/opt/mysqlbackup

[ ! -d $databackupdir ] && mkdir $databackupdir

# 定義郵件正文文件

emailfile=$databackupdir/email.txt

# 定義郵件地址

email=root@localhost.localdomain

# 定義備份日誌文件

logfile=$databackupdir/mysqlbackup.log

DATE=`date -I`

echo "" > $emailfile

echo $(date +"%y-%m-%d %H:%M:%S") >> $emailfile

cd $databackupdir

# 定義備份文件名

dumpfile=mysql_$DATE.sql

gzdumpfile=mysql_$DATE.sql.tar.gz

# 使用mysqldump備份數據庫,請根據具體狀況設置參數

$mysqlDir/bin/mysqldump -u$user -p$userpwd --flush-logs -x $dbname > $dumpfile

# 壓縮備份文件

if [ $? -eq 0 ]; then

tar czf $gzdumpfile $dumpfile >> $emailfile 2>&1

echo "BackupFileName:$gzdumpfile" >> $emailfile

echo "DataBase Backup Success!" >> $emailfile

rm -f $dumpfile

else

echo "DataBase Backup Fail!" >> $emailfile

fi

# 寫日誌文件

echo "--------------------------------------------------------" >> $logfile

cat $emailfile >> $logfile

# 發送郵件通知

cat $emailfile | mail -s "MySQL Backup" $email

mysqldailybackup.sh腳本內容:

[root@localhost ~]# cat mysqldailybackup.sh

#!/bin/sh

# Name:mysqlDailyBackup.sh

# 定義數據庫目錄和數據目錄

mysqldir=/usr/local/mysql

datadir=$mysqldir/data

# 定義用於備份數據庫的用戶名和密碼

user=root

userpwd=123456

# 定義備份目錄,每日備份文件備份到$dataBackupDir/daily

databackupdir=/opt/mysqlbackup

dailybackupdir=$databackupdir/daily

[ ! -d $dailybackupdir ] && mkdir -p $databackupdir/daily

# 定義郵件正文文件

emailfile=$databackupdir/email.txt

# 定義郵件地址

email=root@localhost.localdomain

# 定義日誌文件

logfile=$databackupdir/mysqlbackup.log

echo "" > $emailfile

echo $(date +"%y-%m-%d %H:%M:%S") >> $emailfile

#

# 刷新日誌,使數據庫使用新的二進制日誌文件

$mysqldir/bin/mysqladmin -u$user -p$userpwd flush-logs

cd $datadir

# 獲得二進制日誌列表

filelist=`cat mysql-bin.index`

icounter=0

for file in $filelist

do

icounter=`expr $icounter + 1`

done

nextnum=0

ifile=0

for file in $filelist

do

binlogname=`basename $file`

nextnum=`expr $nextnum + 1`

# 跳過最後一個二進制日誌(數據庫當前使用的二進制日誌文件)

if [ $nextnum -eq $icounter ]; then

echo "Skip lastest!" > /dev/null

else

dest=$dailybackupdir/$binlogname

# 跳過已經備份的二進制日誌文件

if [ -e $dest ]; then

echo "Skip exist $binlogname!" > /dev/null

else

# 備份日誌文件到備份目錄

cp $binlogname $dailybackupdir

if [ $? -eq 0 ]; then

ifile=`expr $ifile + 1`

echo "$binlogname backup success!" >> $emailfile

fi

fi

fi

done

if [ $ifile -eq 0 ];then

echo "No Binlog Backup!" >> $emailfile

else

echo "Backup $ifile File(s)." >> $emailfile

echo "Backup MySQL Binlog OK!" >> $emailfile

fi

# 發送郵件通知

cat $emailfile | mail -s "MySQL Backup" $email

# 寫日誌文件

echo "--------------------------------------------------------" >> $logfile

cat $emailfile >> $logfile

http://hongge.blog.51cto.com/

相關文章
相關標籤/搜索