MySQL不同存儲(chǔ)引擎的數(shù)據(jù)備份與恢復(fù)-創(chuàng)新互聯(lián)

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

創(chuàng)新互聯(lián)長(zhǎng)期為近千家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為象州企業(yè)提供專業(yè)的網(wǎng)站制作、成都網(wǎng)站制作,象州網(wǎng)站改版等技術(shù)服務(wù)。擁有10余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。

1

數(shù)據(jù)備份的目的很直接也很簡(jiǎn)單,就是為了避免因不可預(yù)測(cè)、偶然的事件而導(dǎo)致的慘重?fù)p失,所以數(shù)據(jù)越重要、變化越頻繁,就越要進(jìn)行數(shù)據(jù)備份。本文以MySQL為例,講講面對(duì)不同的存儲(chǔ)引擎如何做數(shù)據(jù)備份與恢復(fù)。

為了應(yīng)對(duì)不同的數(shù)據(jù)處理,MySQL提供了十幾種不同的存儲(chǔ)引擎,不過(guò),我們沒(méi)有必要一 一去了解,因?yàn)槭煜な褂肕ySQL的人都知道,比較常用的存儲(chǔ)引擎有兩個(gè),分別是MyISAM和InnoDB。

MyISAM是MySQL的ISAM擴(kuò)展格式和缺省的數(shù)據(jù)庫(kù)引擎,不支持事務(wù)、也不支持外鍵,但其優(yōu)勢(shì)在于訪問(wèn)速度快,對(duì)事務(wù)完整性沒(méi)有要求,以select,insert為主的應(yīng)用基本上可以用這個(gè)引擎來(lái)創(chuàng)建表。常用于高讀取的應(yīng)用場(chǎng)景數(shù)據(jù)庫(kù),支持三種不同類型的存儲(chǔ)結(jié)構(gòu):靜態(tài)型、動(dòng)態(tài)型、壓縮型。

InnoDB提供了具有提交、回滾和崩潰恢復(fù)能力的事務(wù)安全,支持自動(dòng)增長(zhǎng)列,支持外鍵約束。對(duì)比MyISAM引擎,InnoDB寫(xiě)的處理效率會(huì)差一些,并且會(huì)占用更多的磁盤(pán)空間以保留數(shù)據(jù)和索引。

了解了MySQL常用的兩種存儲(chǔ)引擎之后,我們就來(lái)看看在這兩種引擎中如何進(jìn)行數(shù)據(jù)備份和恢復(fù)。

2

1)MyISAM數(shù)據(jù)備份:

因?yàn)镸yISAM是保存成文件的形式,所以在備份時(shí)有多種方法可以使用,并且大多數(shù)虛擬主機(jī)提供商和INTERNET平臺(tái)提供商只允許使用MyISAM格式,掌握MyISAM數(shù)據(jù)備份就格外重要了。

方法1:文件拷貝:

為了保持?jǐn)?shù)據(jù)備份的一致性,我們可以對(duì)相關(guān)表執(zhí)行LOCK TABLES操作,對(duì)表執(zhí)行FLUSH TABLES。當(dāng)然,你只需要限制寫(xiě)操作,這樣能夠保證在復(fù)制數(shù)據(jù)時(shí),其它操作仍然可以查詢表,而FLUSH TABLES是用來(lái)確保開(kāi)始備份前將所有激活的索引頁(yè)寫(xiě)入硬盤(pán)。

標(biāo)準(zhǔn)流程:鎖表、刷新表到磁盤(pán)、拷貝文件、解鎖。

方法2:SQL語(yǔ)句備份:

SELECT INTO ...OUTFILE或BACKUP TABLE都可以進(jìn)行SQL級(jí)別的表備份,需要注意的是這兩種方法如果有重名文件,最好是先移除重名文件。另外,BACKUP TABLE備份需要注意輸出目錄的權(quán)限,改方法只是備份MYD和frm文件,不備份索引。

方法3: mysqlhotcopy 備份:

mysqlhotcopy 是一個(gè) Perl腳本,使用LOCK TABLES、FLUSH TABLES和cp或scp來(lái)快速備份數(shù)據(jù)庫(kù),但其只能運(yùn)行在數(shù)據(jù)庫(kù)目錄所在的機(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ù),也可以備份單個(gè)表、單個(gè)庫(kù)或者所有庫(kù),輸出是SQL語(yǔ)句文件或者是其它數(shù)據(jù)庫(kù)兼容的格式。在之前的文章中,我們較詳細(xì)的介紹了Mysqldump,本文就不再贅述了。

shell> mysqldump [options] db_name [tables]

shell> mysqldump [options] ---database DB1 [DB2 DB3...]

shell> mysqldump [options] --all—database

方法5:冷備份:

冷備份的方法就很簡(jiǎn)單粗暴了,在MySQL服務(wù)器停止服務(wù)時(shí),復(fù)制所有表文件。

3

2)MyISAM數(shù)據(jù)備份恢復(fù):

不同的備份方式有相應(yīng)的恢復(fù)方法:

如果是mysqldump備份,恢復(fù)方法是mysql –u root < 備份文件名;

如果是mysqlhotcopy或文件冷/熱拷貝備份,恢復(fù)方法是停止MySQL服務(wù),并用備份文件覆蓋現(xiàn)有文件;

如果是BACKUP TABLE備份,使用restore table來(lái)恢復(fù);

如果是SELECT INTO ...OUTFILE備份,使用load data恢復(fù)數(shù)據(jù)或mysqlimport命令。

4

3)InnoDB數(shù)據(jù)備份:

MyISAM不支持事務(wù)和外鍵,這使得MySQL使用者往往會(huì)面臨一些挑戰(zhàn),所以,理所當(dāng)然的當(dāng)InnoDB支持事務(wù)和外鍵時(shí),即使它的速度較慢,也還是獲得了MySQL使用者的青睞。

方法1:mysqldump:

是不是看著很眼熟,沒(méi)錯(cuò)兒,上面MyISAM數(shù)據(jù)備份的方法其中之一就是它。Mysqldump也可以對(duì)InnoDB提供非物理的在線邏輯熱備份,使用方法和MyISAM類似。

方法2:copy file:

InnoDB底層存儲(chǔ)的時(shí)候會(huì)將數(shù)據(jù)和元信息存在ibdata*, *.ibd, *.frm, *.ib_logfile*等文件中,所以備份了這些文件就相當(dāng)于備份了InnoDB數(shù)據(jù)。

方法3:select into:

與MyISAM用法一樣。

方法4:商業(yè)工具:

InnoDB數(shù)據(jù)備份有很多商業(yè)工具可以使用,例如InnoDB Hotbackup,這是一個(gè)在線備份工具,即可以在InnoDB數(shù)據(jù)庫(kù)運(yùn)行時(shí)備份InnoDB數(shù)據(jù)庫(kù); ibbackup,將線上的my.cnf所指向的的數(shù)據(jù)內(nèi)容備份到my.backup.cnf指向的數(shù)據(jù)目錄。

4)InnoDB數(shù)據(jù)備份恢復(fù):

在使用特定的恢復(fù)方法之前,InnoDB數(shù)據(jù)備份恢復(fù)還有兩個(gè)通用的方法,分別是InnoDB的日志自動(dòng)恢復(fù)功能,即重啟mysql服務(wù)和“萬(wàn)能大法”——重啟計(jì)算機(jī)。

如果是mysqldump完全備份,先恢復(fù)完全備份,然后再恢復(fù)完全備份后的增量日志備份。

如果是select into備份表,則采用load data或mysqlimport恢復(fù)。

如果是copy file,那么就停止MySQL服務(wù),備份文件覆蓋當(dāng)前文件,并執(zhí)行上次完全備份后的增量日志備份。

網(wǎng)頁(yè)標(biāo)題:MySQL不同存儲(chǔ)引擎的數(shù)據(jù)備份與恢復(fù)-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)網(wǎng)址:http://muchs.cn/article20/ceogjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、Google、品牌網(wǎng)站建設(shè)品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站設(shè)計(jì)軟件開(kāi)發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

微信小程序開(kāi)發(fā)