国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Linux > 正文

使用shell腳本每天對MySQL多個數據庫自動備份的講解

2019-10-26 18:59:08
字體:
來源:轉載
供稿:網友

Linux下使用shell腳本,結合crontab,定時備份MySQL下多個數據庫,每次備份的數據存放于以日期命名的文件夾中,同時刪除超過設定的備份保留時間的數據。

以下例子設定備份保留時間為1個月(-1month),可根據需求修改

#! /bin/bash# MySQL用戶user="root"# MySQL密碼userPWD="123456"# 需要定時備份的數據表列表dbNames=(db_test1 db_test2 db_test3 db_test4 db_test5)# 每次的備份數據以日期創建文件夾存放,同時刪除過期備份# 此處以保留1個月的備份數據為例DATE=`date -d "now" +%Y%m%d%H`ODATE=`date -d "-1 month" +%Y%m%d%H`newdir=/data/backup/$DATEolddir=/data/backup/$ODATE# 刪除過期備份數據if [ -d $olddir ];  then    rm -rf $olddirfi# 創建新備份文件夾mkdir $newdir# 對備份數據庫列表的所有數據庫備份for dbName in ${dbNames[*]}do  dumpFile=$dbName-$DATE.sql.gz  mysqldump -u$user -p$userPWD $dbName | gzip > $newdir/$dumpFiledone

使用linux計劃任務crontab,定時執行該腳本。

crontab 基本格式 :

*  *  *  *  *  command
分  時   日   月   周    命令
第1列表示分鐘1~59 每分鐘用*或者 */1表示
第2列表示小時1~23(0表示0點)
第3列表示日期1~31
第4列表示月份1~12
第5列標識號星期0~6(0表示星期天)
第6列要運行的命令

輸入命令crontab -e 編輯crontab腳本,編輯完成后保存退出

service crond restart 重新啟動服務即可

例:(假如上面備份腳本保存路徑為/data/backup.sh)

0 0,8,16 * * * /data/backup.sh   #每天8時和16時執行備份

注:請確保備份數據保存的文件夾具有可寫權限

第二天檢查自動生成的sql文件是否符合要求

如果生成的文件和解壓出來查看沒有問題,那么這個自動定時備份數據庫的腳本就算是完成了。因為生成的文件多了會占用一定的空間,所以建議要定期(比如一個月)清理一下文件。

補充

1、如果該數據庫的用戶沒有分配 鎖表 的權限,則備份會報錯 when using LOCK TABLES 。那是因為mysqldump命令默認在導出時是要鎖定表的,所以解決方式有兩個。一個是給該用戶開放 鎖表 的權限;另一個是在命令中加上  --skip-lock-tables 這個參數。即是:

$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

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林站長站的支持。如果你想了解更多相關內容請查看下面相關鏈接

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鹤庆县| 专栏| 楚雄市| 望谟县| 赤城县| 沧州市| 涟源市| 仙居县| 泽州县| 赣州市| 图木舒克市| 新巴尔虎右旗| 德令哈市| 汝城县| 盈江县| 若尔盖县| 泽普县| 闽侯县| 塔河县| 牡丹江市| 阳春市| 武隆县| 苗栗县| 尼木县| 龙海市| 涟源市| 苏州市| 元氏县| 乌什县| 静乐县| 永福县| 河东区| 开原市| 班玛县| 东港市| 赤水市| 久治县| 尉氏县| 民乐县| 无锡市| 石渠县|