作者热门文章
- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章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数据库增量备份的思路和方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有以下场景:有 1 个包含书籍的表和两对包含销售订单和采购订单交易的表 (HD/IT),这些交易通过销售订单 ID 连接。表结构如下: CREATE TABLE `books` ( `id` i
我是一名优秀的程序员,十分优秀!