濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > 使用shell腳本每天對(duì)MySQL多個(gè)數(shù)據(jù)庫自動(dòng)備份的講解

使用shell腳本每天對(duì)MySQL多個(gè)數(shù)據(jù)庫自動(dòng)備份的講解

熱門標(biāo)簽:威海電銷外呼系統(tǒng)好用嗎 武漢語音電銷機(jī)器人加盟 湖北孝感如何辦理 輝縣市地圖標(biāo)注 北京電銷機(jī)器人對(duì)市場(chǎng)的影響 地圖標(biāo)注x是啥意思 外呼系統(tǒng)的合法性 同花順電話機(jī)器人微信 房產(chǎn)證地圖標(biāo)注的兩個(gè)面積

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

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

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

使用linux計(jì)劃任務(wù)crontab,定時(shí)執(zhí)行該腳本。

crontab 基本格式 :

*  *  *  *  *  command
分  時(shí)   日   月   周    命令
第1列表示分鐘1~59 每分鐘用*或者 */1表示
第2列表示小時(shí)1~23(0表示0點(diǎn))
第3列表示日期1~31
第4列表示月份1~12
第5列標(biāo)識(shí)號(hào)星期0~6(0表示星期天)
第6列要運(yùn)行的命令

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

service crond restart 重新啟動(dòng)服務(wù)即可

例:(假如上面?zhèn)浞菽_本保存路徑為/data/backup.sh)

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

注:請(qǐng)確保備份數(shù)據(jù)保存的文件夾具有可寫權(quán)限

第二天檢查自動(dòng)生成的sql文件是否符合要求

如果生成的文件和解壓出來查看沒有問題,那么這個(gè)自動(dòng)定時(shí)備份數(shù)據(jù)庫的腳本就算是完成了。因?yàn)樯傻奈募嗔藭?huì)占用一定的空間,所以建議要定期(比如一個(gè)月)清理一下文件。

補(bǔ)充

1、如果該數(shù)據(jù)庫的用戶沒有分配 鎖表 的權(quán)限,則備份會(huì)報(bào)錯(cuò) when using LOCK TABLES 。那是因?yàn)閙ysqldump命令默認(rèn)在導(dǎo)出時(shí)是要鎖定表的,所以解決方式有兩個(gè)。一個(gè)是給該用戶開放 鎖表 的權(quán)限;另一個(gè)是在命令中加上  --skip-lock-tables 這個(gè)參數(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)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

您可能感興趣的文章:
  • 監(jiān)控MySQL主從狀態(tài)的shell腳本
  • shell腳本一鍵安裝MySQL5.7.29的方法
  • mysql常用備份命令和shell備份腳本分享
  • shell腳本定時(shí)備份MySQL數(shù)據(jù)庫數(shù)據(jù)并保留指定時(shí)間
  • shell腳本自動(dòng)化創(chuàng)建虛擬機(jī)的基本配置之tomcat--mysql--jdk--maven
  • shell腳本實(shí)現(xiàn)mysql定時(shí)備份、刪除、恢復(fù)功能
  • 一個(gè)Shell小腳本精準(zhǔn)統(tǒng)計(jì)Mysql每張表的行數(shù)實(shí)現(xiàn)
  • 通過Shell腳本批量創(chuàng)建服務(wù)器上的MySQL數(shù)據(jù)庫賬號(hào)
  • 使用shell腳本來給mysql加索引的方法
  • 干掉一堆mysql數(shù)據(jù)庫,僅需這樣一個(gè)shell腳本(推薦)
  • MySQL Shell的介紹以及安裝

標(biāo)簽:蚌埠 安康 武威 迪慶 日喀則 西寧 麗江 紹興

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用shell腳本每天對(duì)MySQL多個(gè)數(shù)據(jù)庫自動(dòng)備份的講解》,本文關(guān)鍵詞  使用,shell,腳本,每天,對(duì),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用shell腳本每天對(duì)MySQL多個(gè)數(shù)據(jù)庫自動(dòng)備份的講解》相關(guān)的同類信息!
  • 本頁收集關(guān)于使用shell腳本每天對(duì)MySQL多個(gè)數(shù)據(jù)庫自動(dòng)備份的講解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    佛山市| 泸西县| 神农架林区| 新龙县| 伊吾县| 盐池县| 腾冲县| 瓮安县| 江西省| 贺州市| 徐水县| 正宁县| 肥西县| 秀山| 海伦市| 思南县| 栾川县| 邯郸市| 洛宁县| 庆城县| 定襄县| 漯河市| 耒阳市| 鄯善县| 正蓝旗| 江山市| 永定县| 金乡县| 成武县| 洞头县| 清徐县| 辛集市| 富源县| 思南县| 突泉县| 海淀区| 女性| 清流县| 博罗县| 塔城市| 湖州市|