mysql 全量備份與增量備份


全量備份
[root@master adm]# cat DBfullBak.sh #
!/bin/bash #use mysqldump to fully backup mysql data BakDir=/root/adm/full LogFile=/root/adm/full/bak.log Date=`date +%Y%m%d` Begin=`date +"%Y年%m月%d日 %H:%M:%S"` cd $BakDir DumpFile=$Date.sql GZDumpFile=$Date.sql.tgz mysqldump -uroot -p123456 --all-databases --lock-all-tables --routines --triggers --events --master-data=2 --flush-logs > $DumpFile tar zcvf $GZDumpFile $DumpFile rm $DumpFile Last=`date +"%Y年%m月%d日 %H:%M:%S"` echo 開始:$Begin 結束:$Last $GZDumpFile succ >> $LogFile

參數注釋:

--all-databases #備份所有庫 --lock-all-tables #為所有表加讀鎖 --routinge #存儲過程與函數 --triggers #觸發器 --events #記錄事件 --master-data=2 #在備份文件中記錄當前二進制日志的位置,並且為注釋的,1是不注釋掉在主從復制中才有意義 --flush-logs      #日志滾動一次

 結果如下:

[root@master full]# ls 20170422.sql.tgz bak.log [root@master full]# cat bak.log 開始:2014年07月28日 19:02:59 結束:2014年07月28日 19:02:59 20140728.sql.tgz succ 開始:2014年07月28日 19:12:01 結束:2014年07月28日 19:12:01 20140728.sql.tgz succ [root@master full]#

 

增量備份:

[root@master adm]# cat DBDailyBak.sh #!/bin/bash BakDir=/root/adm/binlog/ BinDir=/var/lib/mysql LogFile=/root/leo/binlog/bak.log BinFile=/var/lib/mysql/mysql-bin.index mysqladmin -uroot -p123456 flush-logs Counter=`wc -l $BinFile|awk '{print $1}'` NextNum=0

for file in `cat $BinFile` do 
    base=`basename $file` NextNum=`expr $NextNum + 1` if [ $NextNum -eq $Counter ] then echo $base skip! >> $LogFile else dest=$BakDir/$base
        if(test -e $dest) then echo $base exist! >> $LogFile else cp $BinDir/$base $BakDir/ echo $base copying >> $LogFile fi fi done echo `date +"%Y年%m月%d日 %H:%M:%S"` $Next Bakup succ~ >> $LogFile

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM