本篇內容介紹了“innobackupex在線(xiàn)備份及恢復的方法”的有關(guān)知識,在實(shí)際案例的操作過(guò)程中,不少人都會(huì )遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學(xué)有所成!
背景介紹:
1、Xtrabackup是什么
Xtrabackup是一個(gè)對InnoDB做數據備份的工具,支持在線(xiàn)熱備份(備份時(shí)不影響數據讀寫(xiě)),是商業(yè)備份工具InnoDB Hotbackup的一個(gè)很好的替代品。
Xtrabackup有兩個(gè)主要的工具:xtrabackup、innobackupex
1、xtrabackup只能備份InnoDB和XtraDB兩種數據表,而不能備份MyISAM數據表
2、 innobackupex是參考了InnoDBHotbackup的innoback腳本修改而來(lái)的.innobackupex是一個(gè)perl腳本封裝,封裝了xtrabackup。主要是為了方便的同時(shí)備份InnoDB和MyISAM引擎的表,但在處理myisam時(shí)需要加一個(gè)讀鎖。并且加入了一些使用的選項。如slave-info可以記錄備份恢復后,作為slave需要的一些信息,根據這些信息,可以很方便的利用備份來(lái)重做slave。
Xtrabackup是由percona開(kāi)發(fā)的一個(gè)開(kāi)源軟件,它是innodb熱備工具ibbackup(收費的商業(yè)軟件)的一個(gè)開(kāi)源替代品。Xtrabackup由個(gè)部分組成:xtrabackup和innobackupex,其中xtrabackup工具用于備份innodb和 xtraDB引擎的表;而innobackupex工具用于備份myisam和innodb引擎的表,本文將介紹如何用innobackupex工具做全量和增量備份。
全備及其恢復:
全備:
執行如下語(yǔ)句進(jìn)行全備:
innobackupex --defaults-file=/opt//my.cnf --user=root --password=*** /backup/mysql/data
該語(yǔ)句將拷貝數據文件(由my.cnf里的變量datadir指定)至備份目錄下(/backup/mysql/data),注意:如果不指定--defaults-file,默認值為/etc/my.cnf。
備份成功后,將在備份目錄下創(chuàng )建一個(gè)時(shí)間戳目錄(本例創(chuàng )建的目錄為/backup/mysql/data/2013-10-29_09-05-25),在該目錄下存放備份文件。
恢復:
恢復之前,要先關(guān)閉數據庫,并且刪除數據文件和日志文件。
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --use-memory=4G --apply-log /backup/mysql/data/2013-10-29_09-05-25
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --copy-back /backup/mysql/data/2013-10-29_09-05-25
從什么可以看出,恢復分為兩個(gè)步驟,第1步是apply-log,為了加快速度,一般建議設置--use-memory,這個(gè)步驟完成之后,目錄/backup/mysql/data/2013-10-29_09-05-25下的備份文件已經(jīng)準備就緒。
第2步是copy-back,即把備份文件拷貝至原數據目錄下。
恢復完成之后,一定要記得檢查數據目錄的所有者和權限是否正確。
增量備份及其恢復:
注意:innobackupex 增量備份僅針對InnoDB這類(lèi)支持事務(wù)的引擎,對于MyISAM等引擎,則仍然是全備。
增量備份:
增量備份需要基于全備或者增量備份,先假設我們已經(jīng)有了一個(gè)全備(/backup/mysql/data/2013-10-29_09-05-25),我們需要在該全備的基礎上做增量備份。
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --incremental-basedir=/backup/mysql/data/2013-10-29_09-05-25 --incremental /backup/mysql/data
其中--incremental-basedir指向全備目錄,--incremental指向增量備份的目錄。
上面語(yǔ)句執行成功之后,會(huì )在--incremental執行的目錄下創(chuàng )建一個(gè)時(shí)間戳子目錄(本例中為:/backup/mysql/data/2013-10-29_09-52-37),在該目錄下存放著(zhù)增量備份的所有文件。
在備份目錄下,有一個(gè)文件xtrabackup_checkpoints記錄著(zhù)備份信息,全備的信息如下:
backup_type = full-backuped
from_lsn = 0
to_lsn = 563759005914
last_lsn = 563759005914
基于該全備的增量備份的信息如下:
backup_type = incremental
from_lsn = 563759005914
to_lsn = 574765133284
last_lsn = 574765133284
從上面可以看出,增量備份的from_lsn正好等于全備的to_lsn。
那么,我們是否可以在增量備份的基礎上再做增量備份呢?答案是肯定的,只要把--incremental-basedir執行上一次增量備份的目錄即可,如下所示:
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --incremental-basedir=/backup/mysql/data/2013-10-29_09-52-37 --incremental /backup/mysql/data
它的xtrabackup_checkpoints記錄著(zhù)備份信息如下:
backup_type = incremental
from_lsn = 574765133284
to_lsn = 574770200380
last_lsn = 574770200950
可以看到,該增量備份的from_lsn是從上一次增量備份的to_lsn開(kāi)始的。
恢復:整個(gè)過(guò)程分為三步驟,整體上可以理解為:可以理解是先把增量備份的數據倒進(jìn)全備份中,然后最后使用全備份恢復即可
第一步:是在所有備份目錄下重做已提交的日志,注意最后一個(gè)增量備份是沒(méi)有--redo-only的,并且數據最后是在全備份中,,如:
innobackupex --apply-log --redo-only BASE-DIR
innobackupex --apply-log --redo-only BASE-DIR --incremental-dir=INCREMENTAL-DIR-1
innobackupex --apply-log BASE-DIR --incremental-dir=INCREMENTAL-DIR-2
其中BASE-DIR是指全備目錄,INCREMENTAL-DIR-1是指第一次的增量備份,INCREMENTAL-DIR-2是指第二次的增量備份,以此類(lèi)推。這里要注意的是:最后一步的增量備份并沒(méi)有--redo-only選項!還有,可以使用--use_memory提高性能。
以上語(yǔ)句執行成功之后,最終數據在BASE-DIR(即全備目錄)下。
第二步:回滾未完成的日志:
innobackupex --apply-log BASE-DIR
上面執行完之后,BASE-DIR里的備份文件已完全準備就緒,
最后一步:是拷貝:
innobackupex --copy-back BASE-DIR
同樣地,拷貝結束之后,記得檢查下數據目錄的權限是否正確。
常見(jiàn)錯誤及解決方法
錯誤:
131028 17:45:57 innobackupex: Connecting to MySQL server with DSN 'dbi:mysql:;mysql_read_default_group=xtrabackup' (using password: NO).
innobackupex: Error: Failed to connect to MySQL server as DBD::mysql module is not installed at /home/mysql/admin/bin/percona-xtrabackup-2.1.5/innobackupex line 2913.
解決方法:
yum -y install perl-DBD-MySQL.x86_64
錯誤:
sh: xtrabackup_55: command not found
innobackupex: Error: no 'mysqld' group in MySQL options at /home/mysql/admin/bin/percona-xtrabackup-2.1.6/innobackupex line 4341.
解決方法:
cp xtrabackup_innodb55 xtrabackup_55
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站