經過 XtraBackup 實現不停機不鎖表搭建主從同步

簡介

Xtrabackup是由 Percona 開發的一個開源軟件,可實現對 InnoDB 的數據備份,支持在線熱備份(備份時不影響數據讀寫)。備份時,Xtrabackup 會將 Master 的 binlog 信息記錄在 xtrabackup_slave_info 文件中,經過此信息能夠方便的搭建主從複製。html

XtraBackup 有兩個工具:xtrabackup 和 innobackupex:mysql

  • xtrabackup 自己只能備份 InnoDB 和 XtraDB ,不能備份 MyISAM;
  • innobackupex 自己是 Hot Backup 腳本修改而來,同時能夠備份 MyISAM 和 InnoDB,可是備份 MyISAM 須要加讀鎖。

官網:http://www.percona.com/software/percona-xtrabackup
文檔:http://www.percona.com/doc/percona-xtrabackup/2.2/index.htmllinux

注:本文服務器環境爲 CentOS,其餘環境請自行修改實現。sql

修改主庫、從庫 MySQL 配置文件

一、Master數據庫

vim /etc/my.cnfvim

datadir=/var/lib/mysql
server-id=1
log-bin=mysql-bin

二、Slave:服務器

vim /etc/my.cnfapp

server-id=2
datadir=/var/lib/mysql

安裝 XtraBackup

一、添加源

yum install http://www.percona.com/downloads/percona-release/redhat/0.1-3/percona-release-0.1-3.noarch.rpm工具

檢查是否添加成功:.net

yum list | grep percona

若是執行正確,其輸出信息一般相似:

percona-release.x86_64                     0.0-1                       installed
...
Percona-Server-client-51.x86_64            5.1.47-rel11.1.51.rhel5     percona
Percona-Server-devel-51.x86_64             5.1.47-rel11.1.51.rhel5     percona
Percona-Server-server-51.x86_64            5.1.47-rel11.1.51.rhel5     percona
Percona-Server-shared-51.x86_64            5.1.47-rel11.1.51.rhel5     percona
Percona-Server-test-51.x86_64              5.1.47-rel11.1.51.rhel5     percona
...
xtrabackup.x86_64                          1.2-22.rhel5                percona

二、安裝 xtrabackup

yum install percona-xtrabackup

建立備份

innobackupex --user=DBUSER --password=DBUSERPASS /path/to/BACKUP-DIR/

若是執行正確,其輸出信息一般相似:

innobackupex: Backup created in directory '/path/to/BACKUP-DIR/2015-03-03_00-00-09'
innobackupex: MySQL binlog position: filename 'mysql-bin.000003', position 1946
111225 00:00:53  innobackupex: completed OK!

備份時,innobackupex 會調用 xtrabackup 備份 InnoDB 表的數據,而且會複製 MyISAM, MERGE,CSV 和 ARCHIVE 表的表定義文件(.frm 文件)、數據文件。同時還會備份觸發器和數據庫配置信息相關的文件。這些文件將會保存在指定備份目錄中一個以時間戳命名的目錄下。

準備備份

通常狀況下,在備份完成後,數據尚且不能用於恢復操做,由於備份的數據中可能會包含還沒有提交的事務或已經提交但還沒有同步至數據文件中的事務。所以,此時數據文件仍處理不一致狀態。「準備」的主要做用正是經過回滾未提交的事務及同步已經提交的事務至數據文件也使得數據文件處於一致性狀態。

innobackupex --apply-log /path/to/BACKUP-DIR

若是執行正確,其最後輸出的幾行信息一般以下:

xtrabackup: starting shutdown with innodb_fast_shutdown = 1
120407  9:01:36  InnoDB: Starting shutdown...
120407  9:01:40  InnoDB: Shutdown completed; log sequence number 92036620
120407 09:01:40  innobackupex: completed OK!

在實現「準備」的過程當中,innobackupex 一般還可使用 --use-memory 選項來指定其可使用的內存的大小,默認一般爲 100M。若是有足夠的內存可用,能夠多劃分一些內存給 prepare 的過程,以提升其完成速度。

恢復備份

將數據複製到從服務器上:
scp -r /path/to/BACKUP-DIR root@slave_host:/data/

在從服務器中恢復備份數據:
innobackupex --copy-back /path/to/BACKUP-DIR

若是服務器剩餘空間不足,你可使用 --move-back 替換掉 --copy-back

若是執行正確,其輸出信息的最後幾行一般以下:

innobackupex: Starting to copy InnoDB log files
innobackupex: in '/backup/2012-04-07_08-17-03'
innobackupex: back to original InnoDB log directory '/mydata/data'
innobackupex: Finished copying back files.
...
120407 09:36:10  innobackupex: completed OK!

啓動從庫 MySQL,設置主庫信息

當數據恢復至數據目錄之後,還須要確保全部數據文件的屬主和屬組均爲正確的用戶,如mysql,不然,在啓動mysqld以前還須要事先修改數據文件的屬主和屬組。如:

chown -R mysql:mysql /mydata/data/

啓動從庫:

/etc/init.d/mysqld start

在主庫中開設主從用的帳號和權限:

GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.0.1' IDENTIFIED BY 'slave';

查看備份文件 xtrabackup_binlog_info 中的日誌文件以及position。

CHANGE MASTER TO
MASTER_HOST='<master_host>',
MASTER_USER='<slave_username>',
MASTER_PASSWORD='<slave_password>',
MASTER_LOG_FILE='<see xtrabackup_binlog_info>',
MASTER_LOG_POS=<see xtrabackup_binlog_info>;

開啓主從同步:

START SLAVE;

查看從庫狀態:

SHOW SLAVE STATUS;

Ps:用 innobackupex 備份數據時,–apply-log 處理過的備份數據裏有兩個文件說明該備份數據對應的 binlog 的文件名和位置。但有時這倆文件說明的位置可能會不一樣。
1 對於純 InnoDB 操做,備份出來的數據中上述兩個文件的內容是一致的
2 對於 InnoDB 和非事務存儲引擎混合操做,xtrabackup_binlog_info 中所示的 position 應該會比 xtrabackup_pos_innodb 所示的數值大。此時應以 xtrabackup_binlog_info 爲準;然後者和 apply-log 時 InnoDB recovery log 中顯示的內容是一致的,只針對 InnoDB 這部分數據。

Ps2:啓動 MySQL 時,遇到權限問題的解決方法:

報錯信息:

150430 14:41:16  InnoDB: Operating system error number 13 in a file operation.
InnoDB: The error means mysqld does not have the access rights to
InnoDB: the directory.

解決方法:
chown -R mysql:mysql /home/data/mysql
chcon -R -t mysqld_db_t /home/mysql

參考資料:

一、http://www.oschina.net/question/1997575_167330
二、http://www.linuxidc.com/Linux/2012-10/71919.htm
三、http://julyclyde.org/?p=403

相關文章
相關標籤/搜索