Linux下使用shell腳本,結(jié)合crontab,定時備份MySQL下多個數(shù)據(jù)庫,每次備份的數(shù)據(jù)存放于以日期命名的文件夾中,同時刪除超過設(shè)定的備份保留時間的數(shù)據(jù)。
以下例子設(shè)定備份保留時間為1個月(-1month),可根據(jù)需求修改
#! /bin/bash# MySQL用戶user="root"# MySQL密碼userPWD="123456"# 需要定時備份的數(shù)據(jù)表列表dbNames=(db_test1 db_test2 db_test3 db_test4 db_test5)# 每次的備份數(shù)據(jù)以日期創(chuàng)建文件夾存放,同時刪除過期備份# 此處以保留1個月的備份數(shù)據(jù)為例DATE=`date -d "now" +%Y%m%d%H`ODATE=`date -d "-1 month" +%Y%m%d%H`newdir=/data/backup/$DATEolddir=/data/backup/$ODATE# 刪除過期備份數(shù)據(jù)if [ -d $olddir ]; then rm -rf $olddirfi# 創(chuàng)建新備份文件夾mkdir $newdir# 對備份數(shù)據(jù)庫列表的所有數(shù)據(jù)庫備份for dbName in ${dbNames[*]}do dumpFile=$dbName-$DATE.sql.gz mysqldump -u$user -p$userPWD $dbName | gzip > $newdir/$dumpFiledone
使用linux計(jì)劃任務(wù)crontab,定時執(zhí)行該腳本。
crontab 基本格式 :
* * * * * command
分 時 日 月 周 命令
第1列表示分鐘1~59 每分鐘用*或者 */1表示
第2列表示小時1~23(0表示0點(diǎn))
第3列表示日期1~31
第4列表示月份1~12
第5列標(biāo)識號星期0~6(0表示星期天)
第6列要運(yùn)行的命令
輸入命令crontab -e
編輯crontab腳本,編輯完成后保存退出
service crond restart
重新啟動服務(wù)即可
例:(假如上面?zhèn)浞菽_本保存路徑為/data/backup.sh)
0 0,8,16 * * * /data/backup.sh #每天8時和16時執(zhí)行備份
注:請確保備份數(shù)據(jù)保存的文件夾具有可寫權(quán)限
第二天檢查自動生成的sql文件是否符合要求
如果生成的文件和解壓出來查看沒有問題,那么這個自動定時備份數(shù)據(jù)庫的腳本就算是完成了。因?yàn)樯傻奈募嗔藭加靡欢ǖ目臻g,所以建議要定期(比如一個月)清理一下文件。
補(bǔ)充
1、如果該數(shù)據(jù)庫的用戶沒有分配 鎖表 的權(quán)限,則備份會報(bào)錯 when using LOCK TABLES 。那是因?yàn)閙ysqldump命令默認(rèn)在導(dǎo)出時是要鎖定表的,所以解決方式有兩個。一個是給該用戶開放 鎖表 的權(quán)限;另一個是在命令中加上 --skip-lock-tables 這個參數(shù)。即是:
$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME --skip-lock-tables| gzip > $BCK_DIR/db_$DATE.sql.gz
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對武林網(wǎng)的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
新聞熱點(diǎn)
疑難解答
圖片精選