今天小編就來為大家講講如何進行MySQL數(shù)據(jù)備份。

1
數(shù)據(jù)備份的目的很直接也很簡單,就是為了避免因不可預測、偶然的事件而導致的慘重損失,所以數(shù)據(jù)越重要、變化越頻繁,就越要進行數(shù)據(jù)備份。本文以MySQL為例,講講面對不同的存儲引擎如何做數(shù)據(jù)備份與恢復。
為了應對不同的數(shù)據(jù)處理,MySQL提供了十幾種不同的存儲引擎,不過,我們沒有必要一 一去了解,因為熟悉使用MySQL的人都知道,比較常用的存儲引擎有兩個,分別是MyISAM和InnoDB。
MyISAM是MySQL的ISAM擴展格式和缺省的數(shù)據(jù)庫引擎,不支持事務、也不支持外鍵,但其優(yōu)勢在于訪問速度快,對事務完整性沒有要求,以select,insert為主的應用基本上可以用這個引擎來創(chuàng)建表。常用于高讀取的應用場景數(shù)據(jù)庫,支持三種不同類型的存儲結(jié)構(gòu):靜態(tài)型、動態(tài)型、壓縮型。
InnoDB提供了具有提交、回滾和崩潰恢復能力的事務安全,支持自動增長列,支持外鍵約束。對比MyISAM引擎,InnoDB寫的處理效率會差一些,并且會占用更多的磁盤空間以保留數(shù)據(jù)和索引。
了解了MySQL常用的兩種存儲引擎之后,我們就來看看在這兩種引擎中如何進行數(shù)據(jù)備份和恢復。
2
1)MyISAM數(shù)據(jù)備份:
因為MyISAM是保存成文件的形式,所以在備份時有多種方法可以使用,并且大多數(shù)虛擬主機提供商和INTERNET平臺提供商只允許使用MyISAM格式,掌握MyISAM數(shù)據(jù)備份就格外重要了。
方法1:文件拷貝:
為了保持數(shù)據(jù)備份的一致性,我們可以對相關(guān)表執(zhí)行LOCK TABLES操作,對表執(zhí)行FLUSH TABLES。當然,你只需要限制寫操作,這樣能夠保證在復制數(shù)據(jù)時,其它操作仍然可以查詢表,而FLUSH TABLES是用來確保開始備份前將所有激活的索引頁寫入硬盤。
標準流程:鎖表、刷新表到磁盤、拷貝文件、解鎖。
方法2:SQL語句備份:
SELECT INTO ...OUTFILE或BACKUP TABLE都可以進行SQL級別的表備份,需要注意的是這兩種方法如果有重名文件,最好是先移除重名文件。另外,BACKUP TABLE備份需要注意輸出目錄的權(quán)限,改方法只是備份MYD和frm文件,不備份索引。
方法3: mysqlhotcopy 備份:
mysqlhotcopy 是一個 Perl腳本,使用LOCK TABLES、FLUSH TABLES和cp或scp來快速備份數(shù)據(jù)庫,但其只能運行在數(shù)據(jù)庫目錄所在的機器上,且只用于備份MyISAM。
shell> mysqlhotcopy db_name [/path/to/new_directory ]
shell> mysqlhotcopy db_name_1 ... db_name_n /path/to/new_directory
方法4: mysqldump 備份:
Mysqldump既可以備份表結(jié)構(gòu)和數(shù)據(jù),也可以備份單個表、單個庫或者所有庫,輸出是SQL語句文件或者是其它數(shù)據(jù)庫兼容的格式。在之前的文章中,我們較詳細的介紹了Mysqldump,本文就不再贅述了。
shell> mysqldump [options] db_name [tables]
shell> mysqldump [options] ---database DB1 [DB2 DB3...]
shell> mysqldump [options] --all—database
方法5:冷備份:
冷備份的方法就很簡單粗暴了,在MySQL服務器停止服務時,復制所有表文件。
3
2)MyISAM數(shù)據(jù)備份恢復:
不同的備份方式有相應的恢復方法:
如果是mysqldump備份,恢復方法是mysql –u root < 備份文件名;
如果是mysqlhotcopy或文件冷/熱拷貝備份,恢復方法是停止MySQL服務,并用備份文件覆蓋現(xiàn)有文件;
如果是BACKUP TABLE備份,使用restore table來恢復;
如果是SELECT INTO ...OUTFILE備份,使用load data恢復數(shù)據(jù)或mysqlimport命令。
4
3)InnoDB數(shù)據(jù)備份:
MyISAM不支持事務和外鍵,這使得MySQL使用者往往會面臨一些挑戰(zhàn),所以,理所當然的當InnoDB支持事務和外鍵時,即使它的速度較慢,也還是獲得了MySQL使用者的青睞。
方法1:mysqldump:
是不是看著很眼熟,沒錯兒,上面MyISAM數(shù)據(jù)備份的方法其中之一就是它。Mysqldump也可以對InnoDB提供非物理的在線邏輯熱備份,使用方法和MyISAM類似。
方法2:copy file:
InnoDB底層存儲的時候會將數(shù)據(jù)和元信息存在ibdata*, *.ibd, *.frm, *.ib_logfile*等文件中,所以備份了這些文件就相當于備份了InnoDB數(shù)據(jù)。
方法3:select into:
與MyISAM用法一樣。
方法4:商業(yè)工具:
InnoDB數(shù)據(jù)備份有很多商業(yè)工具可以使用,例如InnoDB Hotbackup,這是一個在線備份工具,即可以在InnoDB數(shù)據(jù)庫運行時備份InnoDB數(shù)據(jù)庫; ibbackup,將線上的my.cnf所指向的的數(shù)據(jù)內(nèi)容備份到my.backup.cnf指向的數(shù)據(jù)目錄。
4)InnoDB數(shù)據(jù)備份恢復:
在使用特定的恢復方法之前,InnoDB數(shù)據(jù)備份恢復還有兩個通用的方法,分別是InnoDB的日志自動恢復功能,即重啟mysql服務和“萬能大法”——重啟計算機。
如果是mysqldump完全備份,先恢復完全備份,然后再恢復完全備份后的增量日志備份。
如果是select into備份表,則采用load data或mysqlimport恢復。
如果是copy file,那么就停止MySQL服務,備份文件覆蓋當前文件,并執(zhí)行上次完全備份后的增量日志備份。
網(wǎng)頁標題:MySQL不同存儲引擎的數(shù)據(jù)備份與恢復-創(chuàng)新互聯(lián)
網(wǎng)頁網(wǎng)址:http://chinadenli.net/article20/ceogjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、Google、品牌網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計、網(wǎng)站設(shè)計、軟件開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容