久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

innobackupex在線備份及恢復(fù)的方法

共計(jì) 3837 個(gè)字符,預(yù)計(jì)需要花費(fèi) 10 分鐘才能閱讀完成。

本篇內(nèi)容介紹了“innobackupex 在線備份及恢復(fù)的方法”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓丸趣 TV 小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

背景介紹:

1、Xtrabackup 是什么

Xtrabackup 是一個(gè)對(duì) InnoDB 做數(shù)據(jù)備份的工具,支持在線熱備份 (備份時(shí)不影響數(shù)據(jù)讀寫),是商業(yè)備份工具 InnoDB Hotbackup 的一個(gè)很好的替代品。

Xtrabackup 有兩個(gè)主要的工具:xtrabackup、innobackupex

1、xtrabackup 只能備份 InnoDB 和 XtraDB 兩種數(shù)據(jù)表,而不能備份 MyISAM 數(shù)據(jù)表

2、innobackupex 是參考了 InnoDBHotbackup 的 innoback 腳本修改而來的.innobackupex 是一個(gè) perl 腳本封裝,封裝了 xtrabackup。主要是為了方便的同時(shí)備份 InnoDB 和 MyISAM 引擎的表,但在處理 myisam 時(shí)需要加一個(gè)讀鎖。并且加入了一些使用的選項(xiàng)。如 slave-info 可以記錄備份恢復(fù)后,作為 slave 需要的一些信息,根據(jù)這些信息,可以很方便的利用備份來重做 slave。

Xtrabackup 是由 percona 開發(fā)的一個(gè)開源軟件,它是 innodb 熱備工具 ibbackup(收費(fèi)的商業(yè)軟件)的一個(gè)開源替代品。Xtrabackup 由個(gè)部分組成:xtrabackup 和 innobackupex,其中 xtrabackup 工具用于備份 innodb 和 xtraDB 引擎的表;而 innobackupex 工具用于備份 myisam 和 innodb 引擎的表,本文將介紹如何用 innobackupex 工具做全量和增量備份。

全備及其恢復(fù):

全備:

執(zhí)行如下語句進(jìn)行全備:

innobackupex –defaults-file=/opt/mysql/my.cnf  –user=root –password=*** /backup/mysql/data

該語句將拷貝數(shù)據(jù)文件(由 my.cnf 里的變量 datadir 指定)至備份目錄下(/backup/mysql/data),注意:如果不指定 –defaults-file,默認(rèn)值為 /etc/my.cnf。

備份成功后,將在備份目錄下創(chuàng)建一個(gè)時(shí)間戳目錄(本例創(chuàng)建的目錄為 /backup/mysql/data/2013-10-29_09-05-25),在該目錄下存放備份文件。

恢復(fù):

恢復(fù)之前,要先關(guān)閉數(shù)據(jù)庫,并且刪除數(shù)據(jù)文件和日志文件。

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

從什么可以看出,恢復(fù)分為兩個(gè)步驟,第 1 步是 apply-log,為了加快速度,一般建議設(shè)置 –use-memory,這個(gè)步驟完成之后,目錄 /backup/mysql/data/2013-10-29_09-05-25 下的備份文件已經(jīng)準(zhǔn)備就緒。

第 2 步是 copy-back,即把備份文件拷貝至原數(shù)據(jù)目錄下。

恢復(fù)完成之后,一定要記得檢查數(shù)據(jù)目錄的所有者和權(quán)限是否正確。

增量備份及其恢復(fù):

注意:innobackupex 增量備份僅針對(duì) InnoDB 這類支持事務(wù)的引擎,對(duì)于 MyISAM 等引擎,則仍然是全備。

增量備份:

增量備份需要基于全備或者增量備份,先假設(shè)我們已經(jīng)有了一個(gè)全備(/backup/mysql/data/2013-10-29_09-05-25),我們需要在該全備的基礎(chǔ)上做增量備份。

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 指向增量備份的目錄。

上面語句執(zhí)行成功之后,會(huì)在 –incremental 執(zhí)行的目錄下創(chuàng)建一個(gè)時(shí)間戳子目錄(本例中為:/backup/mysql/data/2013-10-29_09-52-37),在該目錄下存放著增量備份的所有文件。

在備份目錄下,有一個(gè)文件 xtrabackup_checkpoints 記錄著備份信息,全備的信息如下:

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。

那么,我們是否可以在增量備份的基礎(chǔ)上再做增量備份呢?答案是肯定的,只要把 –incremental-basedir 執(zhí)行上一次增量備份的目錄即可,如下所示:

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 記錄著備份信息如下:

backup_type = incremental

from_lsn = 574765133284

to_lsn = 574770200380

last_lsn = 574770200950

可以看到,該增量備份的 from_lsn 是從上一次增量備份的 to_lsn 開始的。

恢復(fù):整個(gè)過程分為三步驟,整體上可以理解為:可以理解是先把增量備份的數(shù)據(jù)倒進(jìn)全備份中,然后最后使用全備份恢復(fù)即可

第一步:是在所有備份目錄下重做已提交的日志,注意最后一個(gè)增量備份是沒有 –redo-only 的,并且數(shù)據(jù)最后是在全備份中,,如:

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 是指第二次的增量備份,以此類推。這里要注意的是:最后一步的增量備份并沒有 –redo-only 選項(xiàng)!還有,可以使用 –use_memory 提高性能。

以上語句執(zhí)行成功之后,最終數(shù)據(jù)在 BASE-DIR(即全備目錄)下。

第二步:回滾未完成的日志:

innobackupex –apply-log BASE-DIR

上面執(zhí)行完之后,BASE-DIR 里的備份文件已完全準(zhǔn)備就緒,

最后一步:是拷貝:

innobackupex –copy-back BASE-DIR

同樣地,拷貝結(jié)束之后,記得檢查下數(shù)據(jù)目錄的權(quán)限是否正確。

常見錯(cuò)誤及解決方法

錯(cuò)誤:

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

錯(cuò)誤:

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

“innobackupex 在線備份及恢復(fù)的方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注丸趣 TV 網(wǎng)站,丸趣 TV 小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-08-01發(fā)表,共計(jì)3837字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請(qǐng)注明出處。
評(píng)論(沒有評(píng)論)
主站蜘蛛池模板: 乌拉特中旗| 诏安县| 商都县| 邮箱| 永修县| 育儿| 阜城县| 辽源市| 民县| 广德县| 南陵县| 育儿| 特克斯县| 两当县| 泸水县| 宁陵县| 赣州市| 黄山市| 聂荣县| 沙湾县| 平度市| 合江县| 万全县| 青冈县| 南城县| 隆昌县| 台江县| 剑川县| 鹿泉市| 晋城| 汉阴县| 蒲城县| 游戏| 梁河县| 宣城市| 犍为县| 崇明县| 宾阳县| 太仓市| 会东县| 嫩江县|