熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> MySQL >> 正文

如何實現MySQL數據庫的備份與恢復

2022-06-13   來源: MySQL 

  在數據庫表丟失或損壞的情況下備份你的數據庫是很重要的如果發生系統崩潰你肯定想能夠將你的表盡可能丟失最少的數據恢復到崩潰發生時的狀態有時正是MySQL管理員造成破壞管理員已經知道表以破壞用諸如vi或Emacs等編輯器試圖直接編輯它們這對表絕對不是件好事!
  
  備份數據庫兩個主要方法是用mysqldump程序或直接拷貝數據庫文件(如用cpcpio或tar等)每種方法都有其優缺點
  
  mysqldump與MySQL服務器協同操作直接拷貝方法在服務器外部進行並且你必須采取措施保證沒有客戶正在修改你將拷貝的表如果你想用文件系統備份來備份數據庫也會發生同樣的問題如果數據庫表在文件系統備份過程中被修改進入備份的表文件主語不一致的狀態而對以後的恢復表將失去意義文件系統備份與直接拷貝文件的區別是對後者你完全控制了備份過程這樣你能采取措施確保服務器讓表不受干擾
  
  mysqldump比直接拷貝要慢些
  
  mysqldump生成能夠移植到其它機器的文本文件甚至那些有不同硬件結構的機器上直接拷貝文件不能移植到其它機器上除非你正在拷貝的表使用MyISAM存儲格式ISAM表只能在相似的硬件結構的機器上拷貝在MySQL 中引入的MyISAM表存儲格式解決了該問題因為該格式是機器無關的所以直接拷貝文件可以移植到具有不同硬件結構的機器上只要滿足兩個條件另一台機器必須也運行MySQL 或以後版本而且文件必須以MyISAM格式表示而不是ISAM格式
  
  不管你使用哪種備份方法如果你需要恢復數據庫有幾個原則應該遵守以確保最好的結果
  
  定期實施備份建立一個計劃並嚴格遵守
  
  讓服務器執行更新日志當你在崩潰後需要恢復數據時更新日志將幫助你在你用備份文件恢復數據到備份時的狀態後你可以通過運行更新日志中的查詢再次運用備份後面的修改這將數據庫中的表恢復到崩潰發生時的狀態
  
  以文件系統備份的術語講數據庫備份文件代表完全傾倒(full dump)而更新日志代表漸進傾倒(incremental dump)
  
  使用一種統一的和易理解的備份文件命名機制象backupbuckup等不是特別有意義當實施你的恢復時你將浪費時間找出文件裡是什麼東西你可能發覺用數據庫名和日期構成備份文件名會很有用例如
  
  %mysqldump samp_db >/usr/archives/mysql/samp_db
  %mysqldump menagerie >/usr/archives/mysql/menagerie
  
  你可能想在生成備份後壓縮它們備份一般都很大!你也需要讓你的備份文件有過期期限以避免它們填滿你的磁盤就象你讓你的日志文件過期那樣
  
  用文件系統備份備份你的備份文件如果遇上了一個徹底崩潰不僅清除了你的數據目錄也清除了包含你的數據庫備份的磁盤驅動器你將真正遇上了麻煩也要備份你的更新日志
  
  將你的備份文件放在不同於用於你的數據庫的文件系統上這將降低由於生成備份而填滿包含數據目錄的文件系統的可能性
  
  用於創建備份的技術同樣對拷貝數據庫到另一台機器有用最常見地一個數據庫被轉移到了運行在另一台主機上的服務器但是你也可以將數據轉移到同一台主機上的另一個服務器
  
  使用mysqldump備份和拷貝數據庫
  當你使用mysqldumo程序產生數據庫備份文件時缺省地文件內容包含創建正在傾倒的表的CREATE語句和包含表中行數據的INSERT語句換句話說mysqldump產生的輸出可在以後用作mysql的輸入來重建數據庫
  你可以將整個數據庫傾倒進一個單獨的文本文件中如下
  
  %mysqldump samp_db >/usr/archives/mysql/samp_db
  
  輸出文件的開頭看起來象這樣
  
  # MySQL Dump
  #
  # Host: localhost Database: samp_db
  #
  # Server version alphalog
  #
  # Table structure for table absence
  #
  CREATE TABLE absence(
  student_id int() unsigned DEFAULT NOT NULL
  date date DEFAULT NOT NULL
  PRIMARY KEY (student_iddate)
  );
  #
  # Dumping data for table absence
  #
  INSERT INTO absence VALUES ();
  INSERT INTO absence VALUES ();
  INSERT INTO absence VALUES ();
  
  
  文件剩下的部分有更多的INSERT和CREATE TABLE語句組成
  
  如果你想壓縮備份使用類似如下的命令
  
  %mysqldump samp_db | gzip >/usr/archives/mysql/samp_dbgz
  
  如果你要一個龐大的數據庫輸出文件也將很龐大可能難於管理如果你願意你可以在mysqldump命令行的數據庫名後列出單獨的表名來傾到它們的內容這將傾倒文件分成較小更易於管理的文件下例顯示如何將samp_db數據庫的一些表傾到進分開的文件中
  
  %mysqldump samp_db student score event absence >grapbooksql
  %mysqldump samp_db member president >histleaguesql
  
  如果你生成准備用於定期刷新另一個數據庫內容的備份文件你可能想用adddroptable選項這告訴服務器將DROP TABLE IF EXISTS語句寫入備份文件然後當你取出備份文件並把它裝載進第二個數據庫時如果表已經存在你不會得到一個錯誤
  
  如果你倒出一個數據庫以便能把數據庫轉移到另一個服務器你甚至不必創建備份文件要保證數據庫存在於另一台主機然後用管道傾倒數據庫這樣mysql能直接讀取mysqldump的輸出例如你想從主機拷貝數據庫samp_db到可以這樣很容易做到
  
  %mysqladmin h create samp_db
  %mysqldump samp_db | mysql h samp_db
  
  以後如果你想再次刷新上的數據庫跳過mysqladmin命令但要對mysqldump加上adddroptable以避免的得到表已存在的錯誤
  %mysqldump adddroptable samp_db | mysql h samp_db
  mysqldump其它有用的選項包括
  
  flushlogs和locktables組合將對你的數據庫檢查點有幫助locktables鎖定你正在傾倒的所有表flushlogs關閉並重新打開更新日志文件新的更新日志將只包括從備份點起的修改數據庫的查詢這將設置你的更新日志檢查點位備份時間(然而如果你有需要執行個更新的客戶鎖定所有表對備份期間的客戶訪問不是件好事
  
  如果你使用flushlogs設置檢查點到備份時有可能最好是傾倒整個數據庫如果你傾倒單獨的文件較難將更新日志檢查點與備份文件同步在恢復期間你通常按數據庫為基礎提取更新日志內容對單個表沒有提取更新的選擇所以你必須自己提取它們
  
  缺省地mysqldump在寫入前將一個表的整個內容讀進內存這通常確實不必要並且實際上如果你有一個大表幾乎是失敗的你可用quick選項告訴mysqldump只要它檢索出一行就寫出每一行為了進一步優化傾倒過程使用opt而不是quickopt選項打開其它選項加速數據的傾倒和把它們讀回
  
  用opt實施備份可能是最常用的方法因為備份速度上的優勢然而要警告你opt選項確實有代價opt優化的是你的備份過程不是其他客戶對數據庫的訪問opt選項通過一次鎖定所有表阻止任何人更新你正在傾倒的任何表你可在一般數據庫訪問上很容易看到其效果當你的數據庫一般非常頻繁地使用只是一天一次地調節備份
  
  一個具有opt的相反效果的選項是dedayed該選項使得mysqldump寫出INSERT DELAYED語句而不是INSERT語句如果你將數據文件裝入另一個數據庫並且你想是這個操作對可能出現在該數據庫中的查詢的影響最小delayed對此很有幫助
  
  compress選項在你拷貝數據庫到另一台機器上時很有幫助因為它減少網絡傳輸字節的數量下面有一個例子注意到compress對與遠端主機上的服務器通信的程序才給出而不是對與本地主機連接的程序
  
  %mysqldump opt samp_db | mysql compress h samp_db
  mysqldump有很多選項詳見《MySQL參考手冊》
  
  使用直接拷貝數據庫的備份和拷貝方法
  另一種不涉及mysqldump備份數據庫和表的方式是直接拷貝數據庫表文件典型地這用諸如cptar或cpio實用程序本文的例子使用cp
  
  當你使用一種直接備份方法時你必須保證表不在被使用如果服務器在你則正在拷貝一個表時改變它拷貝就失去意義
  
  保證你的拷貝完整性的最好方法是關閉服務器拷貝文件然後重啟服務器如果你不想關閉服務器要在執行表檢查的同時鎖定服務器如果服務器在運行相同的制約也適用於拷貝文件而且你應該使用相同的鎖定協議讓服務器安靜下來
  
  假設服務器關閉或你已經鎖定了你想拷貝的表下列顯示如何將整個samp_db數據庫備份到一個備份目錄(DATADIR表示服務器的數據目錄)
  
  %cd DATADIR
  %cp r samp_db /usr/archive/mysql
  
  單個表可以如下備份
  
  %cd DATADIR/samp_db
  %cp member* /usr/archive/mysql/samp_db
  %cp score* /usr/archive/mysql/samp_db
  
  
  當你完成了備份時你可
From:http://tw.wingwit.com/Article/program/MySQL/201311/29384.html
    推薦文章
    Copyright © 2005-2022 電腦知識網 Computer Knowledge   All rights reserved.