1. 程式人生 > >MySQL備份恢復工具Xtrabackup

MySQL備份恢復工具Xtrabackup

 

  參考文件https://www.cnblogs.com/youkanyouxiao/p/8335173.html

  

  Xtrabackup介紹

    Xtrabackup是由percona開源的免費資料庫熱備份軟體,它能對InnoDB資料庫和XtraDB儲存引擎的資料庫非阻塞地備份(對於MyISAM的備份同樣需要加表鎖);mysqldump備份方式是採用的邏輯備份,其最大的缺陷是備份和恢復速度較慢,如果資料庫大於50G,mysqldump備份就不太適合。

  Xtrabackup安裝完成後有4個可執行檔案,其中2個比較重要的備份工具是innobackupex、xtrabackup

  1)xtrabackup 是專門用來備份InnoDB表的,和mysql server沒有互動;

  2)innobackupex 是一個封裝xtrabackup的Perl指令碼,支援同時備份innodb和myisam,但在對myisam備份時需要加一個全域性的讀鎖。

  3)xbcrypt 加密解密備份工具

  4)xbstream 流傳打包傳輸工具,類似tar

 

  

  Xtrabackup優點

  Xtrabackup優點

  1)備份速度快,物理備份可靠

  2)備份過程不會打斷正在執行的事務(無需鎖表)

  3)能夠基於壓縮等功能節約磁碟空間和流量

  4)自動備份校驗

  5)還原速度快

  6)可以流傳將備份傳輸到另外一臺機器上

  7)在不增加伺服器負載的情況備份資料

 

  

  Xtrabackup備份原理

  備份原理

  備份開始時首先會開啟一個後臺檢測程序,實時檢測mysq redo的變化,一旦發現有新的日誌寫入,立刻將日誌記入後臺日誌檔案xtrabackup_log中,之後複製innodb的資料檔案一系統表空間檔案ibdatax,複製結束後,將執行flush tables with readlock,然後複製.frm MYI MYD等檔案,最後執行unlock tables,最終停止xtrabackup_log

  

  

  Xtrabackup增量備份介紹

  xtrabackup增量備份的原理是:

  1)、首先完成一個完全備份,並記錄下此時檢查點LSN;

  2)、然後增量備份時,比較表空間中每個頁的LSN是否大於上次備份的LSN,若是則備份該頁並記錄當前檢查點的LSN。

  增量備份優點:

  1)、資料庫太大沒有足夠的空間全量備份,增量備份能有效節省空間,並且效率高;

  2)、支援熱備份,備份過程不鎖表(針對InnoDB而言),不阻塞資料庫的讀寫;

  3)、每日備份只產生少量資料,也可採用遠端備份,節省本地空間;

  4)、備份恢復基於檔案操作,降低直接對資料庫操作風險;

  5)、備份效率更高,恢復效率更高。

 

  Xtrabackup安裝

  環境檢視

 

  下載

wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.12/binary/redhat/7/x86_64/Percona-XtraBackup-2.4.12-r170eb8c-el7-x86_64-bundle.tar

  解壓

tar -xf Percona-XtraBackup-2.4.12-r170eb8c-el7-x86_64-bundle.tar

  安裝依賴包

yum install -y perl-DBD-MySQL
yum -y install perl-Digest-MD5

  安裝

rpm -ivh percona-xtrabackup-24-2.4.12-1.el7.x86_64.rpm

  檢視是否正常安裝

  MySQL建立測試資料庫

mysql> create database test;

Query OK, 1 row affected (0.00 sec)

mysql> use test;

Database changed

mysql> create table T1 (name varchar(10) not null,sex varchar(10) not null);

Query OK, 0 rows affected (0.15 sec)

mysql> insert into T1 values('zhang','man');

Query OK, 1 row affected (0.01 sec)

mysql> insert into T1 values('zhan','man');

Query OK, 1 row affected (0.01 sec)

mysql> insert into T1 values('sun','woman');

Query OK, 1 row affected (0.00 sec)

  

  Xtrabackup全量備份與恢復

  全備

innobackupex --defaults-file=/etc/my.cnf --user=root --password='123456' --backup /root

  --defaults-file指定配置檔案  --user指定使用者名稱 --password指定密碼,需要單引號否則可能報錯 --backup指定備份路徑

  在資料夾/root下面生成一個已當天日誌命名的資料夾

  #使用此引數使用相關資料性檔案保持一致性狀態

 innobackupex --apply-log /root/2018-12-07_15-07-18/

  測試全備恢復,刪除表T1

  恢復資料,需要保持資料目錄是空的狀態,把/var/lib/mysql裡面檔案及資料夾全備刪除

innobackupex --defaults-file=/etc/my.cnf --copy-back /root/2018-12-07_15-07-18/

  預設資料檔案的屬主為root需要修改成mysql

 chown -R mysql.mysql /var/lib/mysql/*

  啟動mysql

systemctl start mysql

  檢視資料回來了

  

  

  Xtrabackup增量備份與恢復

  #需要注意的是,增量備份僅能應用於InooDB或XtraDB表,對於MyISAM表,增量與全備相同

  資料庫新增幾條資料用於測試增量備份

mysql> insert into T1 values('susun','man');
Query OK, 1 row affected (0.02 sec)

mysql> insert into T1 values('sige','man');
Query OK, 1 row affected (0.01 sec)

mysql> insert into T1 values('mgg','man');
Query OK, 1 row affected (0.01 sec)

  建立用於增量備份的資料,用來模擬刪除掉了全備後的資料,能否通過增量備份檔案來恢復

innobackupex --defaults-file=/etc/my.cnf --user=root --password='123456' --incremental /backup/ --incremental-basedir=/root/2018-12-07_15-07-18/

  --incremental指定增量備份的路徑,--incremental-basedir指定上一次全備的路徑

  刪除一條資料用於測試增量備份

delete  from T1 where name='susun';

  增量恢復操作過程如下

innobackupex --apply-log --redo-only /root/2018-12-07_15-07-18/
innobackupex --apply-log --redo-only /root/2018-12-07_15-07-18/ --incremental-dir=/backup/2018-12-07_15-25-56/

  恢復全部資料,同樣需要刪除/var/lib/mysql下所有檔案

innobackupex --defaults-file=/etc/my.cnf --copy-back /root/2018-12-07_15-07-18/

  設定mysql使用者許可權重啟mysql

  檢視是否恢復