做运维这个工作,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