欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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日志打印出来的效果:

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

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数据库增量备份的思路和方法,希望对大家有所帮助