xtrabackup 搭建一个mysql slave

备份要作为备库,所以用了–slave-info参数,备份完成后会生成一个对应主库的binlog日志的文件,用于配置同步。为了保证数据一致性,使用了–slave-info参数后会在某一段时间内加一个全局只读锁,导致库不可写,但是这个要比停止库的同步的影响要小。数据库总共1.4T,前面备份的1.3T都很顺利,没有锁和延时。在备份最后100G数据文件的时候产生了一个全局只读锁,造成了大约3个小时的延迟,备份完成后大概半小时后延时追上了 。下面介绍用xtrabackup 搭建备库的主要步骤:

1.xtrabackup 安装

[root@db-2-43 ~]# cd /usr/src/
[root@db-2-43 src]# wget http://www.percona.com/redir/downloads/XtraBackup/LATEST/binary/Linux/x86_64/percona-xtrabackup-2.1.5-680-Linux-x86_64.tar.gz
[root@db-2-43 src]# tar zxvf percona-xtrabackup-2.1.5-680-Linux-x86_64.tar.gz
[root@db-2-43 src]# cp percona-xtrabackup-2.1.5-Linux-x86_64/bin/* /data/mysql/bin/

xtrabackup是通过DBD::mysql连接和mysql通信,使用前需要安装perl的DBD::mysql模块

通过yum安装

[root@db-2-43 DBD-mysql-4.023]# yum -y install perl-DBD-MySQL.x86_64

或者通过源码安装DBI-DBD

# wget http://search.cpan.org/CPAN/authors/id/T/TI/TIMB/DBI-1.628.tar.gz
# tar zxvf DBI-1.628.tar.gz
# cd DBI-1.628
# perl Makefile.PL
# make && make install
# wget http://search.cpan.org/CPAN/authors/id/C/CA/CAPTTOFU/DBD-mysql-4.023.tar.gz
# tar zxvf DBD-mysql-4.023.tar.gz
# cd DBD-mysql-4.023
# perl Makefile.PL --libs="-L/data/mysql/lib -lmysqlclient -lz -lrt -lcrypt -lnsl -lm" --cflags=" -I/data/mysql/include/"
# make && make install

 

2.开启一个作为slave的完全备份

开启一个完全备份,加入–slave-info参数表明这是一个用来做slave的备份,备份完之后会生成一个xtrabackup_slave_info文件,记录了备份完成后主库的二进制日志文件和位置,用来开启一个同步。

[root@db-2-43 data]# innobackupex --user=root --password= root --port=3306 --defaults-file=/etc/my.cnf --slave-info --socket=/data/mysql/data/mysql.sock --no-timestamp /data/backup/pis_slave

备份成功后会看到如下信息:

innobackupex: Backup created in directory ‘/data/backup/pis_slave’

innobackupex: MySQL slave binlog position: master host ‘10.0.2.44’, filename ‘mysql-bin.012434′, position 525181886

131028 20:20:37  innobackupex: Connection to database server closed

131028 20:20:37  innobackupex: completed OK!

备份完成后,还不能用于恢复,一些未提交的事物需要恢复,需要恢复redo logo的数据,确保数据一致

# innobackupex --apply-log /data/backup/pis_slave/

执行成功会看到如下信息

xtrabackup: starting shutdown with innodb_fast_shutdown = 1

InnoDB: FTS optimize thread exiting.

InnoDB: Starting shutdown…

InnoDB: Shutdown completed; log sequence number 6370833331492

131029 14:12:41  innobackupex: completed OK!

3.备份完成将备份拷贝到新的备库服务器

4.在新备库安装新的mysql数据库。注意的是恢复前要关闭数据库,清空数据库文件目录,因为如果数据目录有存在文件的话是不会覆盖的。然后用下列命令进行数据拷贝恢复,下列命令会将备份出的数据根据my.cnf配置的信息将备份拷贝到mysql数据目录。或者手动将备份文件拷贝到mysql的数据目录也可以。

innobackupex –copy-back /data/backup/pis_slave

5.启动数据库

mysqld_safe --user=mysql --ledir=/data/mysql/bin/ &

6.配置同步

查看主库的binlog位置

[root@db-3-5 pis_slave]# cat xtrabackup_slave_info
CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.012434', MASTER_LOG_POS=525181886

开启同步

14:30:53 (none)>CHANGE MASTER TO
 MASTER_HOST='10.0.2.44',
 MASTER_USER='repl',
 MASTER_PASSWORD='repl',
 MASTER_PORT=3306,
 MASTER_LOG_FILE='mysql-bin.012434',
 MASTER_LOG_POS=525181886,
 MASTER_CONNECT_RETRY=10;
14:33:00 (none)> start slave;

 

基于gtid特性与xtrabackup的数据恢复

在master机器操作

1、在数据库创建备份账号

CREATE USER xtrabk@'localhost' IDENTIFIED BY 'onlyxtrabk!@#$';

GRANT RELOAD, LOCK TABLES, REPLICATION CLIENT,Process ON *.* TO xtrabk@'localhost';

FLUSH PRIVILEGES;

2、备份主库

innobackupex --defaults-file=/etc/my.cnf --user=xtrabk --password='onlyxtrabk!@#$' --parallel=4 /alidata1/backup/full_mysql --no-timestamp

在slave机器操作

1、停止mysql,删除或者重命名Mysql数据目录

systemctl stop mysqld.service

rm -rf /alidata1/mysql/data

rm -rf /alidata1/mysql/redolog

2、应用日志及数据库还原

innobackupex --defaults-file=/etc/my.cnf --apply-log /alidata1/backup/full_mysql

innobackupex --defaults-file=/etc/my.cnf --copy-back /alidata1/backup/full_mysql
3、修改数据目录的宿主权限

chown -R mysql:mysql /alidata1/mysql

4、启动mysql

systemctl start mysqld.service

5.过滤掉已执行过的gtid

cat  xtrabackup_info |grep binlog_pos

6.查看slave已执行的gtid是否为空,如果不为空,需要执行reset MASTER进行清理,否则无法设置gtid。

7.执行reset master

8.执行GTID_PURGED

SET @MYSQLDUMP_TEMP_LOG_BIN = @@SESSION.SQL_LOG_BIN;

SET @@SESSION.SQL_LOG_BIN= 0;

SET @@GLOBAL.GTID_PURGED='c9c73c70-c089-11e7-8544-00163e0ad76e:1-107089934';

SET @@SESSION.SQL_LOG_BIN = @MYSQLDUMP_TEMP_LOG_BIN;

9.change master

change master to

master_host='192.168.2.71',

master_port=3306,

master_user='repl',

master_password='REPLsafe!@#$71',

MASTER_AUTO_POSITION = 1;

10. start slave ;
11.show slave status\G;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值