Mysql数据库增量备份的思路和方法
程序员文章站
2022-06-03 15:05:59
mysql数据库增量备份,在这之前修改我们的数据库配置文件/etc/my.cnf开启bin-log日志功能即可。接下来是我参考了下网上的一些方法,自己写的,主要还是要能学到...
mysql数据库增量备份,在这之前修改我们的数据库配置文件/etc/my.cnf开启bin-log日志功能即可。接下来是我参考了下网上的一些方法,自己写的,主要还是要能学到他的一些思路和方法。
#function:mysql增量备份 #version:1.0.0 #author:wangyanlin #date:2017/08/02 #----------------------------------------------------------------------------------------------- #!/bin/sh export lang=en_us.utf-8 #设置时间 date=`date +%y%m%d` #设置信息 user=root password=withub #设置路径 cd / /usr/bin/mkdir -p mysql_bak/daily /usr/bin/mkdir -p mysql_bak/logs bakdir=/mysql_bak/daily bindir=/var/lib/mysql logfile=/mysql_bak/logs/daily_$date.log binlogfile=/var/lib/mysql/mysql-bin.index /usr/bin/mysqladmin -u$user -p$password flush-logs #刷新日志 counter=`wc -l $binlogfile | awk '{print $1}'` nextnum=0 start_time=`date +'%y-%m-%d %h:%m:%s'` echo `date +"%y年%m月%d日 %h:%m:%s"` $next1 bakup start! >> $logfile #这个for循环用于比对$counter,$nextnum这两个值来确定文件是不是存在或最新的。 for file in `cat $binlogfile` do base=`basename $file` #basename用于截取mysql-bin.00000*文件名,去掉./mysql-bin.000005前面的./ nextnum=`expr $nextnum + 1` if [ $nextnum -eq $counter ] then echo $base skip! >> $logfile 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 echo `date +"%y年%m月%d日 %h:%m:%s"` $next2 bakup succ! >> $logfile end_time=`date +'%y-%m-%d %h:%m:%s'` start_seconds=$(date --date="$start_time" +%s); end_seconds=$(date --date="$end_time" +%s); echo "本次备份运行时间: "$((end_seconds-start_seconds))"s" >> $logfile
添加计划任务:
crontab -e
00 03 * * * /root/mysql_incrementbak.sh #每天的凌晨3点开始增量备份日
logs日志打印出来的效果:
ps:下面看下mysql全量和增量备份脚本
全量:
[root@master leo]# cat dbfullbak.sh #!/bin/bash #use mysqldump to fully backup mysql data bakdir=/root/leo/full logfile=/root/leo/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 20140728.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 leo]# cat dbdailybak.sh #!/bin/bash bakdir=/root/leo/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数据库增量备份的思路和方法,希望对大家有所帮助