天天看點

利用XtraBackup做mysql不停機重做主從複制

不停機做mysql主從同步,可以使用mysqldump,但是這個效率比較低,利用XtraBackup來實作這個,效率比較高!

一 xtrabackup安裝:

yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL

rpm -ivh percona-xtrabackup-2.2.12-1.el6.x86_64.rpm

安裝libenv:

wget ftp://rpmfind.net/linux/atrpms/el6-x86_64/atrpms/stable/libev-4.04-2.el6.x86_64.rpm

XtraBackup軟體下載下傳位址:

軟體下載下傳位址:https://www.percona.com/software/mysql-database/percona-xtrabackup

二 核對mysql的版本:

利用xtrabackup做全備和恢複的,Mysql的版本最好一緻!

檢查mysql版本:

 /webser/mysql55/bin/mysql -V

/webser/mysql55/bin/mysql  Ver 14.14 Distrib 5.5.21, for Linux (x86_64) using readline 5.1

三.在master伺服器上線上備份資料庫:

innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx  /tmp/

備份指定的資料庫:

innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxxx --include='abc.*|salt.*'  /tmp/

注意多個庫之間用“|”符号隔開!

PS:/tmp/為備份目錄;

然後通過scp方式把master上

四.slave機器上操作;

1)關閉mysql服務;

然後清空mysql資料目錄下檔案,例如本機mysql的資料目錄是:/webser/mysql55/var/ 

2)開始恢複資料

假裝置份檔案的路徑在:/tmp/2016-04-29_16-00-54

恢複日志檔案:

innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx --apply-log /tmp/2016-04-29_16-00-54/

恢複資料檔案:

innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx --copy-back /tmp/2016-04-29_16-00-54/

3)修改資料目錄權限:

chown -R mysql:mysql /webser/mysql55/var  

4)安全方式啟動mysql,檢視是否有異常;

/webser/mysql55/bin/mysqld_safe --defaults-file=/webser/mysql55/etc/my.cnf &

如果沒有異常報錯,就關閉mysql

 /webser/mysql55/bin/mysqladmin -uroot -p shutdown

5)檢視binlog日志檔案的位置值,做主從同步:

cat /tmp/2016-04-29_16-00-54/xtrabackup_binlog_info 

wwwmaster.000458    1022022953

6)在slave機器上做主從相關操作:

CHANGE MASTER TO

MASTER_HOST='192.168.3.xxx',

MASTER_USER='mysql_rep',

MASTER_PASSWORD='xxxx',

MASTER_PORT=33066,

MASTER_LOG_FILE='wwwmaster.000458',

MASTER_LOG_POS=1022022953;

啟動主從同步:

start slave;

參考連結:

http://blog.chinaunix.net/uid-20682026-id-3319204.html

http://wsgzao.github.io/post/xtrabackup/

碰到的問題:

1)啟動後報錯:

[root@GuoletaoTest02 etc]# /etc/init.d/mysql55 start

Starting MySQL (Percona Server)...The server quit without u[FAILED]PID file (/data/mysql55/var/GuoletaoTest02.pid).

檢視錯誤日志:

160429 16:47:12 [ERROR] Can't open the mysql.plugin table. Please run mysql_upgrade to create it.

解決辦法:

 ./mysql_install_db --user=mysql --basedir=/webser/mysql55/ --datadir=/data/mysql55/var/

執行以上語句,問題即可解決!

繼續閱讀