91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

innobackupex在線備份及恢復的方法

發布時間:2021-08-17 23:36:13 來源:億速云 閱讀:759 作者:chen 欄目:MySQL數據庫

本篇內容介紹了“innobackupex在線備份及恢復的方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

背景介紹:

1、Xtrabackup是什么

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

Xtrabackup有兩個主要的工具:xtrabackup、innobackupex

1、xtrabackup只能備份InnoDB和XtraDB兩種數據表,而不能備份MyISAM數據表

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

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

全備及其恢復:

全備:

執行如下語句進行全備:

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

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

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

恢復:

恢復之前,要先關閉數據庫,并且刪除數據文件和日志文件。

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

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

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

恢復完成之后,一定要記得檢查數據目錄的所有者和權限是否正確。

增量備份及其恢復:

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

增量備份:

增量備份需要基于全備或者增量備份,先假設我們已經有了一個全備(/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指向增量備份的目錄。

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

在備份目錄下,有一個文件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。

那么,我們是否可以在增量備份的基礎上再做增量備份呢?答案是肯定的,只要把--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記錄著備份信息如下:

backup_type = incremental

from_lsn = 574765133284

to_lsn = 574770200380

last_lsn = 574770200950

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

恢復:整個過程分為三步驟,整體上可以理解為:可以理解是先把增量備份的數據倒進全備份中,然后最后使用全備份恢復即可

第一步:是在所有備份目錄下重做已提交的日志,注意最后一個增量備份是沒有--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是指第二次的增量備份,以此類推。這里要注意的是:最后一步的增量備份并沒有--redo-only選項!還有,可以使用--use_memory提高性能。

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

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

innobackupex --apply-log BASE-DIR

上面執行完之后,BASE-DIR里的備份文件已完全準備就緒,

最后一步:是拷貝:

innobackupex --copy-back BASE-DIR

同樣地,拷貝結束之后,記得檢查下數據目錄的權限是否正確。

常見錯誤及解決方法

錯誤:

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

“innobackupex在線備份及恢復的方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

县级市| 颍上县| 洪湖市| 东丽区| 六安市| 土默特左旗| 峡江县| 仪征市| 滨海县| 张北县| 福贡县| 渝中区| 大田县| 张掖市| 正阳县| 石嘴山市| 万盛区| 永昌县| 田东县| 教育| 阳谷县| 东兰县| 布尔津县| 安泽县| 商丘市| 淮阳县| 天门市| 隆昌县| 石棉县| 新蔡县| 长乐市| 塔河县| 石景山区| 石柱| 油尖旺区| 双桥区| 平江县| 和平区| 潞西市| 济源市| 镇安县|