mysql數(shù)據(jù)庫備份腳本

1. 備份腳本

#!/bin/bash

# MySQL連接信息
DB_HOST="localhost"
DB_USERNAME="root"
DB_PASSWORD="password"

# 要備份的數(shù)據(jù)庫名稱
DATABASES=("database1" "database2")

# 備份文件存放路徑
BACKUP_DIR="/path/to/backup/"
DATE=$(date +%Y-%m-%d)
TIMESTAMP=$(date +%H:%M:%S)
FILENAME="${BACKUP_DIR}/backup_${DATE}_${TIMESTAMP}.tar.gz"

# 創(chuàng)建備份目錄(如果不存在)
mkdir -p $BACKUP_DIR

for db in ${DATABASES[@]}; do
    # 使用mysqldump命令進(jìn)行備份初坠,并重定向輸出到tar壓縮文件中
     mysqldump --host=$DB_HOST --user=$DB_USERNAME --password=$DB_PASSWORD --default-character-set=utf8mb4 $db > "$BACKUP_DIR/$db.sql"
done

# 使用tar命令將每個(gè)數(shù)據(jù)庫的備份文件壓縮為一個(gè)tar.gz文件
tar -czvf "$FILENAME" -C "$BACKUP_DIR" *.sql

# 刪除單個(gè)備份文件
rm -f "$BACKUP_DIR"/*.sql

echo "數(shù)據(jù)庫備份完成世舰!"

這個(gè)腳本將使用mysqldump命令備份每個(gè)數(shù)據(jù)庫,并將結(jié)果保存為單獨(dú)的SQL文件殉簸。然后鲤氢,使用tar命令將這些文件壓縮為一個(gè).tar.gz格式的壓縮文件。最后,刪除備份的SQL文件档叔,并輸出提示消息“數(shù)據(jù)庫備份完成”。

2. 清理腳本

#刪除七天前備份蒸绩,也就是只保存7天內(nèi)的備份
#!/bin/bash
# 備份文件存放路徑
BACKUP_DIR="/path/to/backup/"
find $BACKUP_DIR -name "*.tar.gz" -type f -mtime +7 | xargs -I {} rm -rf {}

3. 設(shè)置定時(shí)任務(wù)

1.輸入 crontab -e 并按回車鍵衙四,這會(huì)打開cron定時(shí)任務(wù)的配置文件。
2.在配置文件中患亿,添加以下行來設(shè)置每天凌晨執(zhí)行備份传蹈、清理腳本:
0 1 * * * /path/to/backup_script.sh
0 2 * * * /path/to/clean_script.sh

4. 可能遇到的問題

4.1 mysql部署在容器中

docker exec mysql sh -c 'exec mysqldump --host=$DB_HOST --user=$DB_USERNAME --password=$DB_PASSWORD --default-character-set=utf8mb4 $db' > "$BACKUP_DIR/$db.sql"
腳本通過如上命令進(jìn)行備份無效,因?yàn)槿萜鲀?nèi)讀不到變量步藕,可以將腳本放置容器內(nèi)惦界,或者建mysql的時(shí)候設(shè)置env

4.2 導(dǎo)出的sql文件存在亂碼

這個(gè)可能和服務(wù)器及文件的字符集有關(guān)。
實(shí)踐過程中我遇到cat中文顯示正常咙冗,vim中文顯示異常的現(xiàn)象沾歪,通過vim中的set fileencoding 查看文件編碼,異常的sql文件編碼為latin1雾消,通過:set fileencoding=utf-8轉(zhuǎn)換仍是顯示異常灾搏?并且導(dǎo)出多個(gè)庫只有一個(gè)sql文件存在這種問題挫望?求指教

vim編碼方面的基礎(chǔ)知識(shí):

存在3個(gè)變量:

encoding—-該選項(xiàng)使用于緩沖的文本(你正在編輯的文件),寄存器确镊,Vim 腳本文件等等士骤。你可以把 ‘encoding’ 選項(xiàng)當(dāng)作是對(duì) Vim 內(nèi)部運(yùn)行機(jī)制的設(shè)定。

fileencoding—-該選項(xiàng)是vim寫入文件時(shí)采用的編碼類型蕾域。

termencoding—-該選項(xiàng)代表輸出到客戶終端(Term)采用的編碼類型拷肌。

此3個(gè)變量的默認(rèn)值:

encoding—與系統(tǒng)當(dāng)前l(fā)ocale相同,所以編輯文件的時(shí)候要考慮當(dāng)前l(fā)ocale旨巷,否則要設(shè)置的東西就比較多了巨缘。

fileencoding—vim打開文件時(shí)自動(dòng)辨認(rèn)其編碼,fileencoding就為辨認(rèn)的值采呐。如果fileencoding為空則保存文件時(shí)采用encoding的編碼珠十,如果沒有修改encoding,那值就是系統(tǒng)當(dāng)前l(fā)ocale了访娶。

termencoding—默認(rèn)空值冰寻,也就是輸出到終端時(shí)不進(jìn)行編碼轉(zhuǎn)換。

4.3 source導(dǎo)入亂碼

登錄時(shí)候加上編碼

mysql --host=$DB_HOST --user=$DB_USERNAME --password=$DB_PASSWORD --default-character-set=utf8mb4

4.4 高版本mysqldump導(dǎo)出低版本mysql數(shù)據(jù)報(bào)錯(cuò)

出現(xiàn)如下報(bào)錯(cuò)信息:
Unknown table 'COLUMN_STATISTICS' in information_schema (1109)
這是由于在mysqldump 8中默認(rèn)啟用了一個(gè)新標(biāo)志煤率,
可以通過添加--column-statistics=0 來禁用它

4.5 crontab不生效

現(xiàn)象:手動(dòng)執(zhí)行命令可以成功仰冠,cron定時(shí)任務(wù)發(fā)現(xiàn)失敗
原因:傳入了一個(gè)日期參數(shù)$(date +%Y%m%d),但是 %在crontab文件里是個(gè)特殊符號(hào)蝶糯,相當(dāng)于回車洋只,因此命令不能正常執(zhí)行
解決:在%前加上反斜杠\,進(jìn)行轉(zhuǎn)義就可以了

另外cron執(zhí)行docker失敗是可能因?yàn)閑xec加了-it參數(shù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末昼捍,一起剝皮案震驚了整個(gè)濱河市识虚,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌妒茬,老刑警劉巖担锤,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異乍钻,居然都是意外死亡妻献,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門团赁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來育拨,“玉大人,你說我怎么就攤上這事欢摄“旧ィ” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵怀挠,是天一觀的道長(zhǎng)析蝴。 經(jīng)常有香客問我害捕,道長(zhǎng),這世上最難降的妖魔是什么闷畸? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任尝盼,我火速辦了婚禮,結(jié)果婚禮上佑菩,老公的妹妹穿的比我還像新娘盾沫。我一直安慰自己,他們只是感情好殿漠,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布赴精。 她就那樣靜靜地躺著,像睡著了一般绞幌。 火紅的嫁衣襯著肌膚如雪蕾哟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天莲蜘,我揣著相機(jī)與錄音谭确,去河邊找鬼。 笑死票渠,一個(gè)胖子當(dāng)著我的面吹牛逐哈,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播庄新,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼薯鼠!你這毒婦竟也來了择诈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤出皇,失蹤者是張志新(化名)和其女友劉穎羞芍,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體郊艘,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡荷科,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了纱注。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片畏浆。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖狞贱,靈堂內(nèi)的尸體忽然破棺而出刻获,到底是詐尸還是另有隱情,我是刑警寧澤瞎嬉,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布蝎毡,位于F島的核電站厚柳,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏沐兵。R本人自食惡果不足惜别垮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望扎谎。 院中可真熱鬧碳想,春花似錦、人聲如沸簿透。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽老充。三九已至葡盗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間啡浊,已是汗流浹背觅够。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留巷嚣,地道東北人喘先。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像廷粒,于是被迫代替她去往敵國(guó)和親窘拯。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容