MySQL数据库备份脚本(逻辑备份&物理备份)
逻辑备份脚本
#!/bin/sh
###每天运行一次
###定义用户 密码 备份目录等信息
user=mysqldump
pwd=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
基于xtrabackup的物理(整库)备份脚本
全备脚本 innobackupex_all.sh
#!/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
增备脚本innobackupex_increment.sh
#!/bin/sh
###周1--周6凌晨4点 增量备份
base_dir=/lyjl/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
恢复脚本innobackupex_restore.sh
#!/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";
原文:http://sykow.blog.51cto.com/3840083/1707203