濮阳杆衣贸易有限公司

主頁 > 知識庫 > MySQL數(shù)據(jù)備份方法的選擇與思考

MySQL數(shù)據(jù)備份方法的選擇與思考

熱門標(biāo)簽:南太平洋地圖標(biāo)注 400電話辦理服務(wù)價格最實惠 大豐地圖標(biāo)注app 400電話變更申請 呂梁外呼系統(tǒng) html地圖標(biāo)注并導(dǎo)航 北京金倫外呼系統(tǒng) 催天下外呼系統(tǒng) 武漢電銷機(jī)器人電話

       從事DBA的行業(yè)也有兩年多了,在數(shù)據(jù)備份上無論是理論和實踐上,都積累了一些經(jīng)驗,恰逢這兩天又出現(xiàn)一些數(shù)據(jù)備份方面的問題,這里,我將之前遇到過的數(shù)據(jù)備份方法簡單做個整理。

       我們都知道,保障數(shù)據(jù)庫的穩(wěn)定、安全、高效運行,是DBA的工作職責(zé)所在。對于DBA來講,要想實現(xiàn)數(shù)據(jù)安全,數(shù)據(jù)備份可能是至關(guān)重要的一個環(huán)節(jié)。

       我曾經(jīng)就遇到過一個案例,業(yè)務(wù)方誤刪數(shù)據(jù)引發(fā)故障,要求DBA恢復(fù)數(shù)據(jù),結(jié)果發(fā)現(xiàn)當(dāng)天的數(shù)據(jù)沒有備份,場面一度十分尷尬,本來這個故障是業(yè)務(wù)引發(fā)的,但是由于沒有數(shù)據(jù)備份,最后業(yè)務(wù)和DBA各打五十大板,一起背鍋。如果業(yè)務(wù)沒有要求DBA恢復(fù)數(shù)據(jù),那么DBA完全可以后續(xù)悄悄的將數(shù)據(jù)備份,最后就可以免于被牽連,當(dāng)然,生產(chǎn)環(huán)境沒有如果。

       備份的重要性,自然不言而喻,那么我們常見的備份思路,都可以有哪些呢?根據(jù)備份是否影響線上環(huán)境,大體可以分為冷備、熱備2種方法,其中冷備可以理解是對線上業(yè)務(wù)有影響,需要離線備份,而熱備是對線上業(yè)務(wù)沒有影響或者影響比較小。

       我自己總結(jié)了以下方法:

1、rsync、cp拷貝文件

這種方法比較暴力,就是直接停止MySQL數(shù)據(jù)庫,然后通過cp、rsync這種Linux物理文件復(fù)制命令,來實現(xiàn)數(shù)據(jù)的備份。

其中:

cp特指的是備份到當(dāng)前服務(wù)器的其他目錄

rsync特指的是備份到其他服務(wù)器上

這種方法,要注意下面幾點:

a、那對于線上環(huán)境來講,rsync的方法會更好,因為如果服務(wù)器宕機(jī)了,cp方法備份也會不可用。

b、rsync和cp的方法,都需要在主從架構(gòu)的從庫上,或者是指定備份庫上進(jìn)行。(這里我推薦線上環(huán)境使用一主一從一備份的復(fù)制架構(gòu))

冷備份的最大的優(yōu)點是速度快、操作簡單。

適合大數(shù)據(jù)庫的日常備份。

2、select xxx into outfile語法

    這種方法,其實往往不能叫做備份,因為它其實只備份了一個表的數(shù)據(jù),但是它非常有用。

    試想這樣一種場景,業(yè)務(wù)方讓你update幾百條數(shù)據(jù),而表中的數(shù)據(jù)有上千萬條,這個時候,如果備份全表,就顯得不那么靈活,而且耗費的時間較長。如果我們使用select的語法,將這些需要修改的數(shù)據(jù),先保存到一個txt的文件中,即使update之后,業(yè)務(wù)反饋和預(yù)期不符,也能快速的找到update之前的樣子,可以極大的縮短你恢復(fù)數(shù)據(jù)的時間。

這種備份方法適合單個表的某一部分?jǐn)?shù)據(jù)變更前的備份。

3、延時從庫

    在MySQL中,這種備份方案相對比較少,在MongoDB中,延時從庫非常常見。但是延時從庫是一種比較好的在線備份手段,它最主要的特點是恢復(fù)的可能性高。

    有些時候,你辛苦備份的數(shù)據(jù),在其他服務(wù)器上,因為各種依賴或者版本問題,導(dǎo)致無法還原一個MySQL實例,這就比較尷尬,而延時從庫可以很好的解決這個問題,因為本身從庫是運行中的,所以不用擔(dān)心庫起不來的情況。

    延時從庫的備份方案中,要控制從庫的延時時間,如果設(shè)置的過短,可能在主庫上引發(fā)問題的SQL已經(jīng)在從庫上執(zhí)行過了,那么就起不到延時的效果,那延時從庫就失去意義了。

4、邏輯備份mysqldump

    這可能是最常見的一種MySQL備份方式了,mysqldump這個官方提供的備份工具,可以提供給你某個時間點的一致性快照,可以很清楚的知道當(dāng)前的時間點,MySQL數(shù)據(jù)庫執(zhí)行到了那個binlog的位點,恢復(fù)的精確性很高。而且,它支持指定庫表備份等,功能非常強(qiáng)大。

     它適合數(shù)據(jù)量在50G以下的數(shù)據(jù)庫備份,超過50G,恢復(fù)的時候會特別慢。

     這個不必多說,大家都知道。

     記得加--single-transaction,要不然可能會出現(xiàn)鎖表,業(yè)務(wù)無法寫入的問題,曾經(jīng)有個小兄弟在這里栽倒了。

     它的特點是能夠給你某個時間點的數(shù)據(jù)庫快照,而且備份文件總體比較小。

5、xtrabackup備份

    這是另外一種熱備份的方式,xtrabackup備份方式可以在不影響數(shù)據(jù)庫寫入的情況下對數(shù)據(jù)庫進(jìn)行熱備,本質(zhì)其實還是物理文件拷貝,比mysqldump的速度要快。

    如果主庫讀寫壓力比較小,則可以在主庫上直接備份。不過還是建議不要在主庫上使用,因為曾經(jīng)出現(xiàn)過線上主庫寫入壓力比較大,xtrabackup直接把主庫備份宕機(jī)的情況出現(xiàn),從庫上不停庫進(jìn)行xtrabackup才是相對比較安全的方法。

 它的特點是備份速度快,備份對線上影響比較小。

6、binlog備份

  binlog備份本質(zhì)上還是SQL語句的備份,類似mysqldump的結(jié)果,不過binlog中保留的數(shù)據(jù)比mysqldump保留的數(shù)據(jù)多一些。

   如果你擁有這個數(shù)據(jù)庫從啟動開始所有的binlog,毋庸置疑,你可以將這個數(shù)據(jù)庫還原出來。但是所有的binlog必定是一個比較比較大的數(shù)據(jù)量,一般很難保留全量日志,所以binlog備份一般情況下需要搭配快照備份。

    我們可以在一個從庫上線停掉復(fù)制關(guān)系,然后flush log新生成一個binlog,記錄為binlog0,然后將這個從庫完整的備份拷貝一份,之后保存binlog0往后的所有binlog,這樣就能利用從庫的完整備份+binlog的方法來恢復(fù)從庫的數(shù)據(jù)。

    binlog備份適用于那些binlog寫入速度一般的數(shù)據(jù)庫,如果你的數(shù)據(jù)庫binlog刷新的速度很快,那數(shù)據(jù)容量可能會成為瓶頸。

7、clone plugin

   clone plugin是8.0的一個亮點功能,既可以支持?jǐn)?shù)據(jù)備份到本地,也可以支持快速遠(yuǎn)程拉起一個數(shù)據(jù)庫的從庫,是一個值得研究的備份方法。之前的文章中也有詳細(xì)些過,有興趣可以去看。也可以參考官方文檔。

    但是目前,線上環(huán)境使用的比較少,原因是大部分國產(chǎn)數(shù)據(jù)庫目前都停留在MySQL5.7版本,當(dāng)然,8.0是趨勢,沒升級的趕快升級吧。

以上就是MySQL數(shù)據(jù)備份方法該如何選擇的詳細(xì)內(nèi)容,更多關(guān)于MySQL 數(shù)據(jù)備份的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySQL數(shù)據(jù)庫備份過程的注意事項
  • shell腳本定時備份MySQL數(shù)據(jù)庫數(shù)據(jù)并保留指定時間
  • Mysql數(shù)據(jù)庫定時備份腳本分享
  • CentOS Mysql數(shù)據(jù)庫如何實現(xiàn)定時備份
  • MySQL數(shù)據(jù)庫備份恢復(fù)實現(xiàn)代碼
  • MySQL數(shù)據(jù)庫入門之備份數(shù)據(jù)庫操作詳解
  • mysql數(shù)據(jù)備份與恢復(fù)實現(xiàn)方法分析
  • MySQL定時備份數(shù)據(jù)庫操作示例
  • mysql 數(shù)據(jù)庫備份的多種實現(xiàn)方式總結(jié)
  • Linux實現(xiàn)定時備份MySQL數(shù)據(jù)庫并刪除30天前的備份文件
  • linux定時備份MySQL數(shù)據(jù)庫并刪除以前的備份文件(推薦)
  • Mysql備份多個數(shù)據(jù)庫代碼實例

標(biāo)簽:徐州 迪慶 自貢 西寧 龍巖 南充 麗水 無錫

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL數(shù)據(jù)備份方法的選擇與思考》,本文關(guān)鍵詞  MySQL,數(shù)據(jù)備份,方法,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL數(shù)據(jù)備份方法的選擇與思考》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL數(shù)據(jù)備份方法的選擇與思考的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    含山县| 建湖县| 泸州市| 青阳县| 铅山县| 淮安市| 吴桥县| 江口县| 远安县| 土默特右旗| 广南县| 义马市| 万荣县| 辉县市| 达日县| 固阳县| 三明市| 孟津县| 杂多县| 霍林郭勒市| 孟州市| 阜新市| 龙游县| 浙江省| 徐州市| 鄂伦春自治旗| 新乡市| 石渠县| 十堰市| 象山县| 新闻| 万盛区| 呼玛县| 庆安县| 斗六市| 淮安市| 惠水县| 佛教| 嵊泗县| 阳江市| 东莞市|