Mysql数据库增量备份的思路和方法

Mysql数据库增量备份的思路和方法

2023年7月30日发(作者:)

Mysql数据库增量备份的思路和⽅法MySQL数据库增量备份,在这之前修改我们的数据库配置⽂件/etc/开启bin-log⽇志功能即可。接下来是我参考了下⽹上的⼀些⽅法,⾃⼰写的,主要还是要能学到他的⼀些思路和⽅法。#function:MYSQL增量备份#version:1.0.0#author:wangyanlin#date:2017/08/02#-----------------------------------------------------------------------------------------------#!/bin/shexport LANG=en_-8#设置时间DATE=`date +%Y%m%d`#设置信息USER=rootPASSWORD=withub#设置路径cd //usr/bin/mkdir -p mysql_bak/daily

/usr/bin/mkdir -p mysql_bak/logsBakDir=/mysql_bak/dailyBinDir=/var/lib/mysqlLogFile=/mysql_bak/logs/Daily_$logFile=/var/lib/mysql//usr/bin/mysqladmin -u$USER -p$PASSWORD flush-logs #刷新⽇志Counter=`wc -l $BinlogFile | awk '{print $1}'`NextNum=0start_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 fidoneecho `date +"%Y年%m⽉%d⽇ %H:%M:%S"` $Next2 Bakup succ! >> $LogFileend_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_ #每天的凌晨3点开始增量备份⽇logs⽇志打印出来的效果:PS:下⾯看下mysql全量和增量备份脚本全量:[root@master leo]# cat

#!/bin/bash#use mysqldump to fully backup mysql dataBakDir=/root/leo/fullLogFile=/root/leo/full/e=`date +%Y%m%d`Begin=`date +"%Y年%m⽉%d⽇ %H:%M:%S"`cd $BakDirDumpFile=$umpFile=$qldump -uroot -p123456 --all-databases --lock-all-tables --routines --triggers --events --master-data=2 --flush-logs > $DumpFiletar zcvf $GZDumpFile $DumpFilerm $DumpFileLast=`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]# [root@master full]# cat

开始:2014年07⽉28⽇ 19:02:59 结束:2014年07⽉28⽇ 19:02:59 succ开始:2014年07⽉28⽇ 19:12:01 结束:2014年07⽉28⽇ 19:12:01 succ[root@master full]#增量备份:[root@master leo]# cat

#!/bin/bashBakDir=/root/leo/binlog/BinDir=/var/lib/mysqlLogFile=/root/leo/binlog/File=/var/lib/mysql/ysqladmin -uroot -p123456 flush-logsCounter=`wc -l $BinFile|awk '{print $1}'`NextNum=0for 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 fidoneecho `date +"%Y年%m⽉%d⽇ %H:%M:%S"` $Next Bakup succ~ >> $LogFile总结以上所述是⼩编给⼤家介绍的Mysql数据库增量备份的思路和⽅法,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!

发布者:admin,转转请注明出处:http://www.yc00.com/xiaochengxu/1690653422a387157.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信