亲测:XtraBackup在线热备份搭建MySQL主从同步

亲测:XtraBackup在线热备份搭建MySQL主从同步_第1张图片
Percona

Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时,Xtrabackup 会将 Master 的 binlog 信息记录在 xtrabackup_slave_info 文件中,通过此信息可以方便的搭建主从复制。
XtraBackup 有两个工具:xtrabackup 和 innobackupex。xtrabackup 本身只能备份 InnoDB 和 XtraDB ,不能备份 MyISAM;innobackupex 本身是 Hot Backup 脚本修改而来,同时可以备份 MyISAM 和 InnoDB,但是备份 MyISAM 需要加读锁。

修改MySQL配置文件

Master
# vim /etc/my.cnf //修改主服务器MySQL的配置文件
server-id=1 //master id需要设定为1
log-bin=mysql-bin // mysql bin日志需要打开

Slave
# vim /etc/my.cnf //修改从服务器MySQL的配置文件
server-id=2 //slave id不能设为1

安装XtraBackup

yum install http://www.percona.com/downloads/percona-release/redhat/0.1-3/percona-release-0.1-3.noarch.rpm //添加源
yum list | grep percona //检查源
yum install percona-xtrabackup

创建备份

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

如果执行正确,其输出信息通常类似:

innobackupex: Backup created in directory '/path/to/BACKUP-DIR/2016-03-23_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!

恢复备份

将数据恢复到从服务器上:

scp -r /path/to/BACKUP-DIR root@slave_host:/data/

关闭从服务器的mysql服务:

sudo /etc/init.d/mysql stop

在从服务器上恢复备份数据:

innobackupex --copy-back  /path/to/BACKUP-DIR

如果从数据库存在多个mysql,则需要使用以下命令:

innobackupex --defaults-file=/etc/my.cnf --defaults-group=mysqld1 --socket=/var/lib/mysql/mysqld1.sock /path/to/BACKUP-DIR

信息设置

修改备份数据的用户和组:

chown -R mysql:mysql /path/to/BACKUP-DIR

在主服务上添加同步用的账号:

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

在从服务器上配置同步账号信息:

CHANGE MASTER TO
MASTER_HOST='',
MASTER_USER='',
MASTER_PASSWORD='',
MASTER_PORT=''
MASTER_LOG_FILE='',
MASTER_LOG_POS=;

开启主从同步:

start slave;

查看状态:

show slave status\G

参考资料:

  • https://segmentfault.com/a/1190000002575399
  • https://www.percona.com/blog/2014/08/26/mysqld_multi-how-to-run-multiple-instances-of-mysql/

你可能感兴趣的:(亲测:XtraBackup在线热备份搭建MySQL主从同步)