增量備份的意思就是在以前數據上進行增加備份了,這樣的數據備份無需大量的操作,只需要小小的變動就可以實現數據備份了,下面給各位整理了一段mysql數據庫完美增量備份腳本,希望對大家有幫助.
是否因為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 --Vevb.com
- 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參數 忽略錯誤
新聞熱點
疑難解答