詳細(xì)說(shuō)明xtrabackup的備份原理
發(fā)表時(shí)間:2023-09-02 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]Percona XtraBackup工作原理Percona XtraBackup是基于InnoDB的崩潰恢復(fù)功能。復(fù)制InnoDB數(shù)據(jù)文件,導(dǎo)致內(nèi)部不一致的數(shù)據(jù); 但隨后它對(duì)文件執(zhí)行崩潰恢復(fù),使它們?cè)俅纬蔀橐恢拢捎玫臄?shù)據(jù)庫(kù)。這是因?yàn)镮nnoDB維護(hù)一個(gè)重做日志,也稱(chēng)為事務(wù)日志。這包含對(duì)InnoD...
Percona XtraBackup工作原理
Percona XtraBackup是基于InnoDB的崩潰恢復(fù)功能。復(fù)制InnoDB數(shù)據(jù)文件,導(dǎo)致內(nèi)部不一致的數(shù)據(jù); 但隨后它對(duì)文件執(zhí)行崩潰恢復(fù),使它們?cè)俅纬蔀橐恢,可用的?shù)據(jù)庫(kù)。
這是因?yàn)?em>InnoDB維護(hù)一個(gè)重做日志,也稱(chēng)為事務(wù)日志。這包含對(duì)InnoDB數(shù)據(jù)的每個(gè)更改的記錄。當(dāng)InnoDB 啟動(dòng)時(shí),它會(huì)檢查數(shù)據(jù)文件和事務(wù)日志,并執(zhí)行兩個(gè)步驟。它將提交的事務(wù)日志條目應(yīng)用于數(shù)據(jù)文件,并對(duì)修改數(shù)據(jù)但未提交的任何事務(wù)執(zhí)行撤銷(xiāo)操作。
Percona XtraBackup通過(guò)記錄日志序列號(hào)(LSN)開(kāi)始工作,然后復(fù)制掉數(shù)據(jù)文件。這需要一小會(huì)時(shí)間來(lái)完成,所以如果文件正在改變,那么它們反映了數(shù)據(jù)庫(kù)在不同時(shí)間點(diǎn)的狀態(tài)。同時(shí),Percona XtraBackup運(yùn)行一個(gè)后臺(tái)進(jìn)程,監(jiān)視事務(wù)日志文件,并從中復(fù)制更改。Percona XtraBackup需要不斷地這樣做,因?yàn)槭聞?wù)日志是以循環(huán)方式編寫(xiě)的,并且可以在一段時(shí)間后重復(fù)使用。Percona XtraBackup從數(shù)據(jù)文件開(kāi)始執(zhí)行以來(lái)每次更改都需要事務(wù)日志記錄。
Percona XtraBackup將使用備份鎖 ,作為一個(gè)輕量級(jí)替代。此功能在Percona Server 5.6+中可用。Percona XtraBackup使用這個(gè)自動(dòng)復(fù)制非InnoDB數(shù)據(jù),以避免阻塞修改InnoDB表的DML查詢(xún)。當(dāng)服務(wù)器支持備份鎖時(shí),xtrabackup將首先復(fù)制InnoDB數(shù)據(jù),運(yùn)行并復(fù)制MyISAM表和.frm文件。一旦完成,文件的備份將開(kāi)始。它將備份.frm,.MRG,.MYD,.MYI,.TRG,F(xiàn)LUSH TABLES WITH READ LOCKLOCK TABLES FOR BACKUP.par
注意
鎖定只對(duì)MyISAM和其他非InnoDB表,只有 在 Percona XtraBackup完成所有InnoDB / XtraDB數(shù)據(jù)和日志后備份。Percona XtraBackup將使用備份鎖 ,作為一個(gè)輕量級(jí)替代。此功能在Percona Server 5.6+中可用。Percona XtraBackup使用這個(gè)自動(dòng)復(fù)制非InnoDB數(shù)據(jù),以避免阻塞修改InnoDB表的DML查詢(xún)。FLUSH TABLES WITH READ LOCK
之后,xtrabackup將使用阻止所有操作,可能更改二進(jìn)制日志位置或 或 報(bào)告。然后xtrabackup將完成復(fù)制REDO日志文件和獲取二進(jìn)制日志坐標(biāo)。在這完成之后xtrabackup將解鎖二進(jìn)制日志和表。LOCK BINLOG FOR BACKUPExec_Master_Log_PosExec_Gtid_SetSHOW MASTER/SLAVE STATUS
最后,二進(jìn)制日志位置將被打印到STDERR和xtrabackup 將退出返回0如果一切正常。
需要注意的是STDERR的xtrabackup不是寫(xiě)在任何文件中。您必須將其重定向到一個(gè)文件,例如,。xtrabackup OPTIONS2> backupout.log
它還將在備份的目錄中創(chuàng)建以下文件。
在準(zhǔn)備階段,Percona XtraBackup使用復(fù)制的事務(wù)日志文件對(duì)復(fù)制的數(shù)據(jù)文件執(zhí)行崩潰恢復(fù)。完成此操作后,數(shù)據(jù)庫(kù)就可以恢復(fù)和使用。
備份的MyISAM和InnoDB表最終將彼此一致,因?yàn)樵跍?zhǔn)備(恢復(fù))過(guò)程之后,InnoDB的數(shù)據(jù)會(huì)前滾到備份完成的點(diǎn),而不會(huì)回滾到該點(diǎn)開(kāi)始。這個(gè)時(shí)間點(diǎn)匹配所采取的位置,因此MyISAM數(shù)據(jù)和準(zhǔn)備的 InnoDB數(shù)據(jù)是同步的。FLUSH TABLES WITHREAD LOCK
簡(jiǎn)而言之,這些工具允許您通過(guò)復(fù)制數(shù)據(jù)文件,復(fù)制日志文件以及將日志應(yīng)用到數(shù)據(jù)的各種組合來(lái)執(zhí)行流式和增量備份等操作。
以上就是詳細(xì)介紹xtrabackup的備份原理的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門(mén)到精通的SQL知識(shí)。