兩套mysql備份指令碼

來源:互聯網
上載者:User

標籤:mysql備份指令碼 邏輯備份 物理備份 xtrabackup備份自動回複指令碼

    資料備份其重要性無需多言,再細想一步,我們至少需要兩種備份:一種邏輯備份(mysqldump產生sql檔案);一種物理備份(xtrabackup可很好完成)。邏輯備份在出問題時能提供更細粒度的恢複和對比;物理備份在整庫範圍的資料恢複或者增加從庫方面有著更高額效率。


首先看下邏輯備份指令碼,比較簡單

#!/bin/sh###每天運行一次###定義使用者 密碼 備份目錄等資訊user=mysqldumppsd=mysqldumpbackup_base=/data/mysql_backupdate=`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、innobackupex_increment.sh、innobackupex_restore.sh

    我們知道xtrabackup可以第一次備份全量資料,之後設定增量備份。Linux crontab以數字0-6表示"周日"-"周六"。所以,我以一周為周期:周日進行全備,存放於0目錄;周一至周六增備,存放於1-6目錄;下次周日清空目錄重新全備。

    上面以0-6這樣的目錄名存放備份資料,是為了讓恢複指令碼innobackupex_restore.sh處理起來更方便。無論在周幾執行恢複指令碼,都能正確的執行xtrabackup的恢複過程

    依percona官方文檔。xtrabackup備份至少需要以下許可權:GRANT RELOAD, SUPER, LOCK TABLES, REPLICATION CLIENT, CREATE TABLESPACE ON *.* TO ‘xtrabackup‘@‘localhost‘ identified by xxxx


計劃任務設定如下

650) this.width=650;" src="http://s3.51cto.com/wyfs02/M02/74/9C/wKiom1YjllLjfwWHAABUb2Zxa3Q422.jpg" title="456.png" alt="wKiom1YjllLjfwWHAABUb2Zxa3Q422.jpg" />


全備指令碼 innobackupex_all.sh

#!/bin/sh###每周日淩晨4點,執行全量備份base_dir=/ljk/datarm -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.logcd $base_dir#將以‘目前時間命名的全備目錄‘重新命名為‘0‘mv 20* 0 2>> $base_dir/all.log


增備指令碼innobackupex_increment.sh

#!/bin/sh###周1--周6淩晨4點 增量備份base_dir=/ljk/datatoday=`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.logcd $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/databackup_dir=`ls -l $base_dir|grep -e "^d.*"|awk ‘{print $NF}‘`echo -e "the backup dir is: $backup_dir \n"sleep 1###開始恢複cd $base_direcho -e "------ 準備階段 0 ------\n"sleep 1/usr/bin/innobackupex --apply-log --redo-only $base_dir/0check "準備階段 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/0check "應用所有變化到$base_dir/0";###將資料考回資料目錄echo -e "------ 將處理好的資料考回至資料目錄 ------\n"/usr/bin/innobackupex --copy-back $base_dir/0check "copy-back";


物理備份目錄結構

650) this.width=650;" src="http://s3.51cto.com/wyfs02/M00/74/9E/wKiom1YkT2Hy8NGHAACa4O-rEnA967.jpg" title="123.png" alt="wKiom1YkT2Hy8NGHAACa4O-rEnA967.jpg" />

本文出自 “奮進的K” 部落格,請務必保留此出處http://kaifly.blog.51cto.com/3209616/1704105

兩套mysql備份指令碼

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.