mysql備份腳本

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 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://kaifly.blog.51cto.com/3209616/1704105

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章