美文网首页首页投稿(暂停使用,暂停投稿)程序员
亲测:XtraBackup在线热备份搭建MySQL主从同步

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

作者: 天空极高处的风 | 来源:发表于2016-03-25 11:35 被阅读2056次
    PerconaPercona

    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
    

    参考资料:

    相关文章

      网友评论

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

        本文链接:https://www.haomeiwen.com/subject/vosrlttx.html