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


本文摘自PHP中文网,作者黄舟,侵删。

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

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

#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全量和增量备份脚本

全量:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

[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

参数注释:

1

2

3

4

5

6

7

--all-databases #备份所有库

--lock-all-tables #为所有表加读锁

--routinge  #存储过程与函数

--triggers  #触发器

--events   #记录事件

--master-data=2 #在备份文件中记录当前二进制日志的位置,并且为注释的,1是不注释掉在主从复制中才有意义

--flush-logs  #日志滚动一次

结果如下:

1

2

3

4

5

6

[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]#

增量备份:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

[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数据库增量备份的实现思路方法介绍的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

怎么查看mysql进程

mysql如何在原值增加

mysql使用profile分析sql开销的代码

数据库具有的三个基本特点是什么

添加mysql的用户名和密码是什么语句?

mysql服务的路径不对怎么办

mysql事务详细介绍

mysql聚集索引的有哪些缺点

linux下更改mysql数据文件默认路径

mysql 中行转列的方法

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...