xtrabackup是由percona提供的mysql備份工具,它是一款物理備份工具,通過連接資料庫把資料庫的數據備份出來。對於innodb存儲引擎其支持全量備份和增量備份。對於myisam存儲引擎只支持增量備份。因為xtrabackup對innodb的增量備份是基於表空間的LSN進行的,所謂LSN ...
xtrabackup是由percona提供的mysql備份工具,它是一款物理備份工具,通過連接資料庫把資料庫的數據備份出來。對於innodb存儲引擎其支持全量備份和增量備份。對於myisam存儲引擎只支持增量備份。因為xtrabackup對innodb的增量備份是基於表空間的LSN進行的,所謂LSN即:表空間分成多個數據塊,每個數據塊都有相應的序列號,當數據塊數據發生變化則更新序列號。全量備份即備份所有數據塊,則增量備份則基於全量備份最後一個數據塊的序列號到最新的數據塊序列號進行備份。因為myisam不支持表空間,所以不能進行增量備份。
xtrabackup備份出來的數據包括:
- 表空間
- 數據文件
- 二進位日誌
- 事務日誌
...
xtrabackup在進行數據恢復之前需要註意如下要點:
- 如果有增量備份則需要在恢復之前先進行增量備份和全備份的合併再恢復;
- 如果是支持事務的表的備份,則恢復之前需要先進行事務日誌的回滾和提交操作;
- 如果是多個連續的備份操作,則只需要提交事務日誌,不需要回滾,只有在全部備份操作合成之後再進行事務的回滾;
此文通過詳細的實驗步驟來演示xtrabackup的使用方法。
實驗步驟
- 一臺centos7虛擬機,安裝mariadb-5.5.52版本的資料庫,首先通過sql腳本導入hellodb測試庫,其包括一個students數據表,此實驗在students表中進行操作,命令如下:
mysql -uroot < hellodb.sql
- 安裝xtrabackup,可以從官方網站下載安裝包,然後通過yum進行安裝,下載站點為:https://www.percona.com/downloads/XtraBackup/LATEST/,此處不再演示安裝過程;
- xtrabackup的主要命令為innobackupex,通過innobackupex --help或者man手冊可以獲取到幫助信息;
- 資料庫已經導入,此時可以進行資料庫的備份操作,先進行資料庫的全量備份和恢復:
- 首先確保資料庫已經開啟二進位日誌,通過show global variables like 'log_bin';命令可以看到是否已經開啟,通過show binary logs;可以看到目前正在使用的二進位日誌是哪一個;
- 通過xtrabackup進行備份,數據備份到/data/backup目錄下,備份完成會在指定目錄下生成一個以當前時間命名的文件夾:
innobackupex -u root /data/backup
- 文件夾內容如下:
- xtrabackup_binlog_info:記錄二進位日誌的內容;
- xtrabackup_checkpoints:記錄備份類型,開始和結束的lsn編號等備份信息;
- xtrabackup_info:記錄更詳細的備份信息,如是否為所有庫備份,是否壓縮,備份執行的命令等信息;
- xtrabackup_logfile:記錄的是事務日誌,為二進位文件,不可查看;
- 此時就備份成功了,然後演示資料庫的恢復操作。註意:恢復之前需要首先停止資料庫服務:
innobackupex --apply-log 2017-07-13_21-02-07/ #首先進行事務日誌的提交和回滾 innobackupex --copy-back 2017-07-13_21-02-07/ #進行數據恢復,會自動把數據恢復到mysql的數據目錄下
- 恢覆成功之後所有已經恢複數據的屬主和屬組都是root用戶,需要修改成mysql用戶才能登陸資料庫;
- 此時登陸資料庫即可看到所有數據都已經恢復了。
- 這次演示增量備份和恢復操作:
- 往資料庫中插入幾條新的信息,然後進行資料庫的增量備份;
- 通過如下命令進行資料庫的增量備份,備份成功之後還是會在/data/backup目錄下生成一個新的以時間命名的文件夾:
innobackupex -u root -p 1234567a --incremental --incremental-basedir=/data/backup/2017-07-13_21-07-23/ /data/backup/
- 然後停掉資料庫服務,刪除資料庫目錄下的所有數據,進行數據恢復操作,步驟如下:
innobackupex --apply-log --redo-only 2017-07-13_22-16-19/ #進行全量備份的事務提交,但是不回滾未提交事務,因為未提交事務可能在下次的增量備份中提交 innobackupex --apply-log --redo-only 2017-07-13_22-16-19/ --incremental-dir=2017-07-13_22-18-34/ #進行增量備份和全備份的合成已經事務提交工作 innobackupex --apply-log 2017-07-13_22-16-19/ #對於全備份也沒有完成的事務進行回滾操作 innobackupex --copy-back 2017-07-13_22-16-19/ #此時採用全備份即可恢複數據,不再需要增量備份,因為已經進行了備份的合成操作
同樣需要修改恢復完成數據的屬主和屬組,然後登陸資料庫即可看到完整是數據,此時實驗演示完成。
註意:
- 生產環境建議二進位日誌和數據文件分開放在不同磁碟,因為二進位文件可以用來進行時間點恢復,可以儘可能保證丟失更少的數據,如果二進位文件也丟失,則可能會丟失大量數據;
- 在數據恢復操作完成之後一定要再進行一次數據的全備份,保證數據安全;