国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關(guān)注微信公眾號(hào)

MySQL數(shù)據(jù)庫備份
2007-11-12   IT168

在數(shù)據(jù)庫表丟失或損壞的情況下,備份你的數(shù)據(jù)庫是很重要的。如果發(fā)生系統(tǒng)崩潰,你肯定想能夠?qū)⒛愕谋肀M可能丟失最少的數(shù)據(jù)恢復(fù)到崩潰發(fā)生時(shí)的狀態(tài)。有時(shí),正是MySQL管理員造成破壞。管理員已經(jīng)知道表以破壞,用諸如vi或Emacs等編輯器試圖直接編輯它們,這對(duì)表絕對(duì)不是件好事!

備份數(shù)據(jù)庫兩個(gè)主要方法是用mysqldump程序或直接拷貝數(shù)據(jù)庫文件(如用cp、cpio或tar等)。每種方法都有其優(yōu)缺點(diǎn):
  • mysqldump與MySQL服務(wù)器協(xié)同操作。直接拷貝方法在服務(wù)器外部進(jìn)行,并且你必須采取措施保證沒有客戶正在修改你將拷貝的表。如果你想用文件系統(tǒng)備份來備份數(shù)據(jù)庫,也會(huì)發(fā)生同樣的問題:如果數(shù)據(jù)庫表在文件系統(tǒng)備份過程中被修改,進(jìn)入備份的表文件主語不一致的狀態(tài),而對(duì)以后的恢復(fù)表將失去意義。文件系統(tǒng)備份與直接拷貝文件的區(qū)別是對(duì)后者你完全控制了備份過程,這樣你能采取措施確保服務(wù)器讓表不受干擾。
  • mysqldump比直接拷貝要慢些。
  • mysqldump生成能夠移植到其它機(jī)器的文本文件,甚至那些有不同硬件結(jié)構(gòu)的機(jī)器上。直接拷貝文件不能移植到其它機(jī)器上,除非你正在拷貝的表使用MyISAM存儲(chǔ)格式。ISAM表只能在相似的硬件結(jié)構(gòu)的機(jī)器上拷貝。在MySQL 3.23中引入的MyISAM表存儲(chǔ)格式解決了該問題,因?yàn)樵摳袷绞菣C(jī)器無關(guān)的,所以直接拷貝文件可以移植到具有不同硬件結(jié)構(gòu)的機(jī)器上。只要滿足兩個(gè)條件:另一臺(tái)機(jī)器必須也運(yùn)行MySQL 3.23或以后版本,而且文件必須以MyISAM格式表示,而不是ISAM格式。


不管你使用哪種備份方法,如果你需要恢復(fù)數(shù)據(jù)庫,有幾個(gè)原則應(yīng)該遵守,以確保最好的結(jié)果:
  • 定期實(shí)施備份。建立一個(gè)計(jì)劃并嚴(yán)格遵守。
  • 讓服務(wù)器執(zhí)行更新日志。當(dāng)你在崩潰后需要恢復(fù)數(shù)據(jù)時(shí),更新日志將幫助你。在你用備份文件恢復(fù)數(shù)據(jù)到備份時(shí)的狀態(tài)后,你可以通過運(yùn)行更新日志中的查詢?cè)俅芜\(yùn)用備份后面的修改,這將數(shù)據(jù)庫中的表恢復(fù)到崩潰發(fā)生時(shí)的狀態(tài)。

    以文件系統(tǒng)備份的術(shù)語講,數(shù)據(jù)庫備份文件代表完全傾倒(full dump),而更新日志代表漸進(jìn)傾倒(incremental dump)。
  • 使用一種統(tǒng)一的和易理解的備份文件命名機(jī)制。象backup1、buckup2等不是特別有意義。當(dāng)實(shí)施你的恢復(fù)時(shí),你將浪費(fèi)時(shí)間找出文件里是什么東西。你可能發(fā)覺用數(shù)據(jù)庫名和日期構(gòu)成備份文件名會(huì)很有用。例如:

    %mysqldump samp_db >/usr/archives/mysql/samp_db.1999-10-02

    %mysqldump menagerie >/usr/archives/mysql/menagerie.1999-10-02

    你可能想在生成備份后壓縮它們。備份一般都很大!你也需要讓你的備份文件有過期期限以避免它們填滿你的磁盤,就象你讓你的日志文件過期那樣。
  • 用文件系統(tǒng)備份備份你的備份文件。如果遇上了一個(gè)徹底崩潰,不僅清除了你的數(shù)據(jù)目錄,也清除了包含你的數(shù)據(jù)庫備份的磁盤驅(qū)動(dòng)器,你將真正遇上了麻煩。也要備份你的更新日志。
  • 將你的備份文件放在不同于用于你的數(shù)據(jù)庫的文件系統(tǒng)上。這將降低由于生成備份而填滿包含數(shù)據(jù)目錄的文件系統(tǒng)的可能性。


用于創(chuàng)建備份的技術(shù)同樣對(duì)拷貝數(shù)據(jù)庫到另一臺(tái)機(jī)器有用。最常見地,一個(gè)數(shù)據(jù)庫被轉(zhuǎn)移到了運(yùn)行在另一臺(tái)主機(jī)上的服務(wù)器,但是你也可以將數(shù)據(jù)轉(zhuǎn)移到同一臺(tái)主機(jī)上的另一個(gè)服務(wù)器。

1 使用mysqldump備份和拷貝數(shù)據(jù)庫



當(dāng)你使用mysqldumo程序產(chǎn)生數(shù)據(jù)庫備份文件時(shí),缺省地,文件內(nèi)容包含創(chuàng)建正在傾倒的表的CREATE語句和包含表中行數(shù)據(jù)的INSERT語句。換句話說,mysqldump產(chǎn)生的輸出可在以后用作mysql的輸入來重建數(shù)據(jù)庫。

你可以將整個(gè)數(shù)據(jù)庫傾倒進(jìn)一個(gè)單獨(dú)的文本文件中,如下:

%mysqldump samp_db >/usr/archives/mysql/samp_db.1999-10-02

輸出文件的開頭看起來象這樣:
# MySQL Dump 6.0# # Host: localhost    Database: samp_db#---------------------------------------
# Server version 3.23.2-alpha-log## Table structure for table 'absence'#CREATE TABLE absence(  
student_id int(10) unsigned DEFAULT '0' NOT NULL,  date date DEFAULT '0000-00-00' NOT NULL,  

熱詞搜索:

上一篇:數(shù)據(jù)庫備份可能出錯(cuò)的十種情況總結(jié)
下一篇:Sun宣布將全面進(jìn)軍虛擬化市場(chǎng)

分享到: 收藏
主站蜘蛛池模板: 台安县| 崇文区| 双牌县| 广元市| 凉山| 青阳县| 凭祥市| 莲花县| 军事| 泰安市| 忻州市| 广州市| 长顺县| 加查县| 株洲县| 泸溪县| 竹溪县| 衡水市| 普格县| 东海县| 新民市| 蒙自县| 喀喇沁旗| 攀枝花市| 揭东县| 绥宁县| 财经| 桓台县| 济宁市| 宜州市| 新津县| 仁怀市| 九寨沟县| 文昌市| 千阳县| 通江县| 道孚县| 宁阳县| 旬邑县| 文昌市| 博兴县|