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"
;