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
|
#!/bin/sh ###每天运行一次 ###定义用户 密码 备份目录等信息 user=mysqldump psd=mysqldump backup_base= /data/mysql_backup date =` date +%Y%m%d` old_date=` date +%Y%m%d -d -30days` ###保存的天数 ###获取库名,排除不需要备份的库 for db in `mysql -u$user -p$psd -s -N -e "show databases" | grep - v -E "(test|percona|information_schema|performance_schema)" ` do ###创建备份目录 if [ ! -d $backup_base/$db ]; then mkdir $backup_base/$db fi cd $backup_base/$db chattr -i ./* rm -f $old_date.sql* &> /dev/null #删除30天以前的 mysqldump -u$user -p$psd --events --routines $db | gzip > $ date .sql.gz ###备份&压缩 chattr +i ./* ###这里加了个防误删的属性 done |
1
2
3
4
5
6
7
8
9
10
11
12
13
|
#!/bin/sh ###每周日凌晨4点,执行全量备份 base_dir= /ljk/data rm -rf $base_dir/* 2>> $base_dir /all .log ###清空base_dir,执行全备 ###备份并将日志记录于base_dir下的all.log /usr/bin/innobackupex --user=xtrabackup --password=xtrabackup $base_dir 2>> $base_dir /all .log cd $base_dir #将以'当前时间命名的全备目录'重命名为'0' mv 20* 0 2>> $base_dir /all .log |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
#!/bin/sh ###周1--周6凌晨4点 增量备份 base_dir= /ljk/data today=` date +%u` yesterday=` expr $today - 1` echo -e "\n===================================\n" >> $base_dir /increment .log ###增备日志记录于$base_dir/increment.log /usr/bin/innobackupex --user=xtrabackup --password=xtrabackup --incremental $base_dir --incremental-basedir=$base_dir/$yesterday 2>> $base_dir /increment .log cd $base_dir #重命名备份文件,以0 1 2 3 4 5 6 代表周日到 周六 mv 20* $today 2>> $base_dir /increment .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
52
53
|
#!/bin/sh ###检查上次命令执行是否成功的函数 function check { if [ $? - ne 0 ]; then echo -e "\e[1;31m\n $1 exec failed,please check it !\e[0m \n" echo "$1 failed,please check it !" sleep 1 exit -1 fi } base_dir= /ljk/data backup_dir=` ls -l $base_dir| grep -e "^d.*" | awk '{print $NF}' ` echo -e "the backup dir is: $backup_dir \n" sleep 1 ###开始恢复 cd $base_dir echo -e "------ 准备阶段 0 ------\n" sleep 1 /usr/bin/innobackupex --apply-log --redo-only $base_dir /0 check "准备阶段 0" ; ###执行除去 0 和 最后一个目录 之外的其他目录的恢复准备 dir_num=` ls -l $base_dir| grep -e "^d.*" | wc -l` #取出有几个备份目录 for i in ` seq 1 $(($dir_num - 2))` do echo -e "------ 准备阶段 $i ------ \n" sleep 1 /usr/bin/innobackupex --apply-log --redo-only $base_dir /0 --incremental- dir =$base_dir/$i check "准备阶段 $i" ; done ###最后一个增量备份 echo -e "------ 准备阶段 $(($dir_num - 1)) ------ \n" sleep 1 /usr/bin/innobackupex --apply-log $base_dir /0 --incremental- dir =$base_dir/$(($dir_num - 1)) check "准备阶段 $(($dir_num - 1))" ; ###以上步骤将所有增量备份中记录的变化应用到了最初的全量备份中 echo -e "------ 应用所有变化到$base_dir/0 ------\n" /usr/bin/innobackupex --apply-log $base_dir /0 check "应用所有变化到$base_dir/0" ; ###将数据考回数据目录 echo -e "------ 将处理好的数据考回至数据目录 ------\n" /usr/bin/innobackupex --copy-back $base_dir /0 check "copy-back" ; |