明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

用xtrabackup備份mysql數(shù)據(jù)庫方法指導(dǎo)

[摘要]xtrabackup是由percona提供的mysql備份工具,它是一款物理備份工具,通過連接數(shù)據(jù)庫把數(shù)據(jù)庫的數(shù)據(jù)備份出來。對于innodb存儲引擎其支持全量備份和增量備份。對于myisam存儲引擎...

xtrabackup是由percona提供的mysql備份工具,它是一款物理備份工具,通過連接數(shù)據(jù)庫把數(shù)據(jù)庫的數(shù)據(jù)備份出來。對于innodb存儲引擎其支持全量備份和增量備份。對于myisam存儲引擎只支持增量備份。因為xtrabackup對innodb的增量備份是基于表空間的LSN進行的,所謂LSN即:表空間分成多個數(shù)據(jù)塊,每個數(shù)據(jù)塊都有相應(yīng)的序列號,當數(shù)據(jù)塊數(shù)據(jù)發(fā)生變化則更新序列號。全量備份即備份所有數(shù)據(jù)塊,則增量備份則基于全量備份最后一個數(shù)據(jù)塊的序列號到最新的數(shù)據(jù)塊序列號進行備份。因為myisam不支持表空間,所以不能進行增量備份。

Xtrabackup是由percona提供的mysql數(shù)據(jù)庫備份工具,據(jù)官方介紹,這也是世界上惟一一款開源的能夠?qū)nnodb和xtradb數(shù)據(jù)庫進行熱備的工具。

Xtrabackup中主要包含兩個工具:

xtrabackup:是用于熱備份innodb, xtradb表中數(shù)據(jù)的工具,不能備份其他類型的表,也不能備份數(shù)據(jù)表結(jié)構(gòu);

innobackupex:是將xtrabackup進行封裝的perl腳本,可以備份和恢復(fù)MyISAM表以及數(shù)據(jù)表結(jié)構(gòu)。


xtrabackup備份出來的數(shù)據(jù)包括:

  • 表空間

  • 數(shù)據(jù)文件

  • 二進制日志

  • 事務(wù)日志
    ...

xtrabackup在進行數(shù)據(jù)恢復(fù)之前需要注意如下要點:

  1. 如果有增量備份則需要在恢復(fù)之前先進行增量備份和全備份的合并再恢復(fù);

  2. 如果是支持事務(wù)的表的備份,則恢復(fù)之前需要先進行事務(wù)日志的回滾和提交操作;

  3. 如果是多個連續(xù)的備份操作,則只需要提交事務(wù)日志,不需要回滾,只有在全部備份操作合成之后再進行事務(wù)的回滾;

此文通過詳細的實驗步驟來演示xtrabackup的使用方法。
實驗步驟

  1. 一臺centos7虛擬機,安裝mariadb-5.5.52版本的數(shù)據(jù)庫,首先通過sql腳本導(dǎo)入hellodb測試庫,其包括一個students數(shù)據(jù)表,此實驗在students表中進行操作,命令如下:
    mysql -uroot < hellodb.sql

  2. 安裝xtrabackup,可以從官方網(wǎng)站下載安裝包,然后通過yum進行安裝,下載站點為:,此處不再演示安裝過程;

  3. xtrabackup的主要命令為innobackupex,通過innobackupex --help或者man手冊可以獲取到幫助信息;

  4. 數(shù)據(jù)庫已經(jīng)導(dǎo)入,此時可以進行數(shù)據(jù)庫的備份操作,先進行數(shù)據(jù)庫的全量備份和恢復(fù):

    • xtrabackup_binlog_info:記錄二進制日志的內(nèi)容;

    • xtrabackup_checkpoints:記錄備份類型,開始和結(jié)束的lsn編號等備份信息;

    • xtrabackup_info:記錄更詳細的備份信息,如是否為所有庫備份,是否壓縮,備份執(zhí)行的命令等信息;

    • xtrabackup_logfile:記錄的是事務(wù)日志,為二進制文件,不可查看;

    1. 首先確保數(shù)據(jù)庫已經(jīng)開啟二進制日志,通過show global variables like 'log_bin';命令可以看到是否已經(jīng)開啟,通過show binary logs;可以看到目前正在使用的二進制日志是哪一個;

    2. 通過xtrabackup進行備份,數(shù)據(jù)備份到/data/backup目錄下,備份完成會在指定目錄下生成一個以當前時間命名的文件夾:
      innobackupex -u root /data/backup

    3. 文件夾內(nèi)容如下:

    4. 此時就備份成功了,然后演示數(shù)據(jù)庫的恢復(fù)操作。注意:恢復(fù)之前需要首先停止數(shù)據(jù)庫服務(wù):
      innobackupex --apply-log 2017-07-13_21-02-07/ #首先進行事務(wù)日志的提交和回滾 innobackupex --copy-back 2017-07-13_21-02-07/ #進行數(shù)據(jù)恢復(fù),會自動把數(shù)據(jù)恢復(fù)到mysql的數(shù)據(jù)目錄下

    5. 恢復(fù)成功之后所有已經(jīng)恢復(fù)數(shù)據(jù)的屬主和屬組都是root用戶,需要修改成mysql用戶才能登陸數(shù)據(jù)庫;

    6. 此時登陸數(shù)據(jù)庫即可看到所有數(shù)據(jù)都已經(jīng)恢復(fù)了。

  5. 這次演示增量備份和恢復(fù)操作:

    • 生產(chǎn)環(huán)境建議二進制日志和數(shù)據(jù)文件分開放在不同磁盤,因為二進制文件可以用來進行時間點恢復(fù),可以盡可能保證丟失更少的數(shù)據(jù),如果二進制文件也丟失,則可能會丟失大量數(shù)據(jù);

    • 在數(shù)據(jù)恢復(fù)操作完成之后一定要再進行一次數(shù)據(jù)的全備份,保證數(shù)據(jù)安全;

    1. 往數(shù)據(jù)庫中插入幾條新的信息,然后進行數(shù)據(jù)庫的增量備份;

    2. 通過如下命令進行數(shù)據(jù)庫的增量備份,備份成功之后還是會在/data/backup目錄下生成一個新的以時間命名的文件夾:
      innobackupex -u root -p 1234567a --incremental --incremental-basedir=/data/backup/2017-07-13_21-07-23/ /data/backup/

    3. 然后停掉數(shù)據(jù)庫服務(wù),刪除數(shù)據(jù)庫目錄下的所有數(shù)據(jù),進行數(shù)據(jù)恢復(fù)操作,步驟如下:
      innobackupex --apply-log --redo-only 2017-07-13_22-16-19/ #進行全量備份的事務(wù)提交,但是不回滾未提交事務(wù),因為未提交事務(wù)可能在下次的增量備份中提交 innobackupex --apply-log --redo-only 2017-07-13_22-16-19/ --incremental-dir=2017-07-13_22-18-34/ #進行增量備份和全備份的合成已經(jīng)事務(wù)提交工作 innobackupex --apply-log 2017-07-13_22-16-19/ #對于全備份也沒有完成的事務(wù)進行回滾操作 innobackupex --copy-back 2017-07-13_22-16-19/ #此時采用全備份即可恢復(fù)數(shù)據(jù),不再需要增量備份,因為已經(jīng)進行了備份的合成操作

    4. 同樣需要修改恢復(fù)完成數(shù)據(jù)的屬主和屬組,然后登陸數(shù)據(jù)庫即可看到完整是數(shù)據(jù),此時實驗演示完成。

      注意:

以上就是用xtrabackup備份mysql數(shù)據(jù)庫方法指導(dǎo)的詳細內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門到精通的SQL知識。