欢迎来访~

mysql全量备份、增量备份脚本

做运维这个工作,mysql备份是必不可少的,下面分享下我在使用的全量备份、增量备份脚本,供大家参考。

mysqldump增量备份配置

执行增量备份的前提条件是MySQL打开binlog日志功能
查找mysql的配置文件my.cnf
find / -name my.cnf
默认路径一般为 /etc/my.cnf
vim /etc/my.cnf
在[mysqld]下面增加
log-bin=mysql-bin
“log-bin=”后的字符串为日志记载目录,可根据情况自行更改,也可以默认不变。
如我的记载目录设置为:log-bin=/usr/local/mysql/var/data/mysql-bin
设置完成后需要重启mysql服务。

mysql备份文件保存位置

先创建保存mysql备份文件的位置,一般建议放在不同于MySQL数据目录的磁盘上。
mkdir -p /home/mysql/backup/daily
我的mysql全量备份文件存放位置:/home/mysql/backup
我的mysql全量备份文件存放位置:/home/mysql/backup/daily

mysql全量备份脚本

vim /root/js/mysql-fully-bak.sh
#!/bin/bash
# Program
# use mysqldump to Fully backup mysql data per week!
# History
# Path
BakDir=/home/mysql/backup
LogFile=/home/mysql/backup/bak.log
Date=`date +%Y%m%d`
Begin=`date +"%Y年%m月%d日 %H:%M:%S"`
cd $BakDir
DumpFile=$Date.sql
GZDumpFile=$Date.sql.tgz
/usr/local/mysql/bin/mysqldump -uroot -p123456*** --quick --events --all-databases --flush-logs --delete-master-logs --single-transaction > $DumpFile
echo \@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ >> $LogFile
/bin/tar -zvcf $GZDumpFile $DumpFile
/bin/rm $DumpFile

#只保留过去四周的数据库内容
#count=$(ls -l  *.tgz |wc -l)
#if [ $count -ge 5 ]
#then
#file=$(ls -l *.tgz |awk '{print $9}'|awk 'NR==1')
#/bin/rm -f  $file
#fi
#

Last=`date +"%Y年%m月%d日 %H:%M:%S"`
echo $GZDumpFile >> $LogFile
echo 开始:$Begin 结束:$Last  mysql-fully-bak successful !!! >> $LogFile
echo   >> $LogFile

#/bin/rm -f $BakDir/daily/*      #进行全量备份后删除增量备份文件

 

mysql增量备份脚本

vim /root/js/mysql-daily-bak.sh
#!/bin/bash
# Program
# use cp to backup mysql data everyday!
# History
# Path
BakDir=/home/mysql/backup/daily         #增量备份时复制mysql-bin.00000*的目标目录,提前手动创建这个目录
BinDir=/usr/local/mysql/var/data                 #mysql数据存放目录
LogFile=/home/mysql/backup/bak.log             #备份日志存放目录
BinFile=/usr/local/mysql/var/data/mysql-bin.index       #mysql数据目录下的index文件
Date=`date +%Y%m%d`
Begin=`date +"%Y年%m月%d日 %H:%M:%S"`
/usr/local/mysql/bin/mysqladmin -uroot -p123456****  flush-logs
#这个是用于产生新的mysql-bin.00000*文件
Counter=`wc -l $BinFile |awk '{print $1}'`
NextNum=0
#这个for循环用于比对$Counter,$NextNum这两个值来确定文件是不是存在或最新的
echo \######################################################  >> $LogFile
 
for file in `cat $BinFile`
do
    base=`basename $file`
    #basename用于截取mysql-bin.00000*文件名,去掉./mysql-bin.000005前面的./
    NextNum=`expr $NextNum + 1`
    if [ $NextNum -eq $Counter ]
    then
         echo $base skip! > /dev/null
    else
        dest=$BakDir/$base
        if(test -e $dest)
        #test -e用于检测目标文件是否存在,存在就写exist!到$LogFile去
        then
            echo $base exist! >> $LogFile
        else
            cp $BinDir/$base $BakDir
            echo $base copying >> $LogFile
         fi
     fi
done
Last=`date +"%Y年%m月%d日 %H:%M:%S"`
echo 开始:$Begin 结束:$Last$Next mysql-daily-backup successful !!! >> $LogFile
echo    >> $LogFile
ls -l -h  $BakDir

 

设置crontab任务,定时执行备份脚本

[root@jiangwei backup]# crontab -e
添加以下任务
#每个星期日凌晨3:00执行完全备份脚本
0 3 * * 0 /root/js/mysql-fully-bak.sh >/dev/null 2>&1
#周一到周六凌晨3:00做增量备份
0 3 * * 1-6 /root/js/mysql-daily-bak.sh >/dev/null 2>&1

 

 

 

赞(3)
可附来源转载:一只北极熊 » mysql全量备份、增量备份脚本

富强、民主、文明、和谐、自由、平等、公正、法治、爱国、敬业、诚信、友善