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_host>',
MASTER_USER='<slave_username>',
MASTER_PASSWORD='<slave_password>',
MASTER_PORT='<master_port>'
MASTER_LOG_FILE='<see xtrabackup_binlog_info>',
MASTER_LOG_POS=<see xtrabackup_binlog_info>;
开启主从同步:
start slave;
查看状态:
show slave status\G