• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Mysql数据库增量备份的实现思路方法介绍

mysql 搞代码 4年前 (2022-01-09) 26次浏览 已收录 0个评论

MySQL数据库增量备份,在这之前修改我们的数据库配置文件/etc/my.cnf开启bin-log日志功能即可,下面小编给大家分享Mysql数据库增量备份的思路详解,一起看看吧

MySQL数据库增量备份,在这之前修改我们的数据库配置文件/etc/my.cnf开启bin-log日志功能即可。接下来是我参考了下网上的一些方法,自己写的,主要还是要能学到他的一些思路和方法。

#function:MYSQL增量备份#version:1.0.0#author:wangyanlin#date:2017/08/02#-----------------------------------------------------------------------------------------------#!/bin/shexport LANG=en_US.UTF-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_$DATE.logBinlogFile=/var/lib/mysql/mysql-bin.index/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    els<div style="color:transparent">本文来源gaodai.ma#com搞##代!^码@网*</div>e      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_incrementbak.sh #每天的凌晨3点开始增量备份日

logs日志打印出来的效果:

PS:下面看下mysql全量和增量备份脚本

全量:

[root@master leo]# cat DBfullBak.sh #!/bin/bash#use mysqldump to fully backup mysql dataBakDir=/root/leo/fullLogFile=/root/leo/full/bak.logDate=`date +%Y%m%d`Begin=`date +"%Y年%m月%d日 %H:%M:%S"`cd $BakDirDumpFile=$Date.sqlGZDumpFile=$Date.sql.tgzmysqldump -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]# ls20140728.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/bashBakDir=/root/leo/binlog/BinDir=/var/lib/mysqlLogFile=/root/leo/binlog/bak.logBinFile=/var/lib/mysql/mysql-bin.indexmysqladmin -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数据库增量备份的实现思路方法介绍的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Mysql数据库增量备份的实现思路方法介绍

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址