mysql資料庫完美增量備份指令碼

來源:互聯網
上載者:User


是否因為mysql太大,來回備份浪費資源頻寬而發愁,如果想解決這個麻煩就需要增量備份,下面是張小三資源網修改的一份mysql的增量備份指令碼,我已做了相關注釋,大家自行修改下就可以用了。

vi /etc/my.cnf開啟日誌及定期清理日誌

log-bin=mysql-bin
binlog_format=mixed
//二進位日誌自動刪除的天數。預設值為0,表示“沒有自動刪除”
expire_logs_days = 5
全備份指令碼:
#!/bin/bash
# Name:qbk全備份指令碼
# mysql qbk scripts
# By zxsdw.com
# Last Modify:2015-01-21
#定義指令碼存放路徑
#scriptsDir=/usr/sbin
#定義使用者名稱及密碼
user=root
userPWD=密碼
#定義要備份的資料庫
database=資料庫
#定義完全備份檔案存放路徑
bakDir=/backup/mysql
#eMailFile=$bakDir/email.txt
#eMail=admin@zxsdw.com
#定義記錄檔
LogFile=$bakDir/mysqlbak.log
DATE=`date +%Y%m%d`
echo " " >> $LogFile
echo " " >> $LogFile
echo "--------------------------" >> $LogFile
echo $(date +"%y-%m-%d %H:%M:%S") >>$LogFile
echo "-----------------" >> $LogFile
cd $bakDir
DumpFile=$DATE.sql.gz
mysqldump --flush-logs -u$user -p$userPWD --quick $database| gzip >$DumpFile
echo "Dump Done" >> $LogFile
echo  "[$DumpFile]Backup Success!" >> $LogFile
daily_databakDir=$bakDir/daily_backup
cd $bakDir/daily_backup
find $daily_databakDir -name "daily*" -type f -mtime +35 -exec rm {} \; > /dev/null 2>&1
增量備份指令碼:
#!/bin/bash
# Name:zbk增量備份
# mysql zbk scripts
# By zxsdw.com
# Last modify:2015-01-21


#定義資料庫使用者名稱及密碼
user=root
userPWD=密碼
#定義資料庫
database=資料庫
#產生一個新的mysql-bin.00000X檔案,如果err日誌被清除,則自動建立一個。
/usr/local/mysql/bin/mysqladmin -u$user -p$userPWD flush-logs
#定義增量備份位置
daily_databakDir=/backup/mysql/daily_backup
#定義MYSQL資料日誌目錄
mysqlDataDir=/usr/local/mysql/var
#定義增量日誌及目錄
eMailFile=$daily_databakDir/email.txt
#eMail=admin@zxsdw.com
#定義變數DATE格式為20150127
DATE=`date +%Y%m%d`
#定義一個總的logFile日誌
logFile=$daily_databakDir/mysql$DATE.log


#美化日誌模板
echo "       " > $eMailFile
echo "-----------------------" >> $eMailFile
#時間格式為15-01-27 01:06:17
echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile
echo "-------------------------" >> $eMailFile


#定義刪除bin日誌的時間範圍,格式為20150124010540
TIME=$(date "-d 3 day ago" +%Y%m%d%H%M%S)
#定義需要增量備份資料的時間範圍,格式為2015-01-26 01:04:11
StartTime=$(date "-d 1 day ago" +"%Y-%m-%d %H:%M:%S")

###########開始刪除操作美化日誌標題##############
echo "Delete 3 days before the log" >>$eMailFile

#刪除三天前的bin檔案,及更新index裡的索引記錄,美化日誌標題
mysql -u$user -p$userPWD -e "purge master logs before ${TIME}" && echo "delete 3 days before log" |tee -a $eMailFile

#尋找index索引裡的bin 2進位檔案並賦值給 i。
filename=`cat $mysqlDataDir/mysql-bin.index |awk -F "/" '{print $2}'`
for i in $filename
do
#########開始增量備份操作,美化日誌標題###########
echo "$StartTime start backup binlog" >> $eMailFile

#利用mysqlbinlog備份1天前增加的資料,並gzip壓縮打包到增量備份目錄
/usr/local/mysql/bin/mysqlbinlog -u$user -p$userPWD -d $database --start-datetime="$StartTime" $mysqlDataDir/$i |gzip >> $daily_databakDir/daily$DATE.sql.gz |tee -a $eMailFile

done

 

#如果以上備份指令碼執行成功,接著運行下面的刪除指令碼
if [ $? = 0 ]
then
# 刪除mtime>32的增量記錄備份檔案
find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
cd $daily_databakDir
echo "Daily backup succeed" >> $eMailFile
else
echo "Daily backup fail" >> $eMailFile
#mail -s "MySQL Backup" $eMail < $eMailFile #備份失敗之後發送郵件通知
#fi結束IF判斷
fi


#把變數eMailFile的內容替換logFile內容

cat $eMailFile > $logFile

#如果上面的IF判斷失敗,再次運行刪除mtime>32的增量記錄備份檔案
find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
rsync -vzrtopg --delete --progress --password-file=/usr/local/rsync/rsync.passwd root@$ip:/zxs/allimg/$(date -d -1day +%y%m%d) /zxs/allimg/
gunzip < /backup/mysql/daily_backup/ceshi.sql.gz | /usr/local/mysql/bin/mysql -u使用者名稱 -p密碼 資料庫名 --force
--force參數 忽略錯誤

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.