mysql 全量备份与增量备份

Posted 大道至简

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 全量备份与增量备份相关的知识,希望对你有一定的参考价值。

全量备份
[[email protected] 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      #日志滚动一次

 结果如下:

[[email protected] full]# ls
20170422.sql.tgz  bak.log
[[email protected] 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
[[email protected] full]#

 

增量备份:

[[email protected] 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

 


以上是关于mysql 全量备份与增量备份的主要内容,如果未能解决你的问题,请参考以下文章

mysql全量备份与增量备份

mysql 全量备份与增量备份

MySQL的备份与还原,非常规备份,全量备份,增量备份

MySQL数据库之Percona全量增量备份与恢复

MySQL全量增量备份与恢复

MySQL全量增量备份与恢复(重点!!!)