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
檢視是否恢復