最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

通过XtraBackup实现不停机不锁表搭建MySQL主从同步

来源:懂视网 责编:小采 时间:2020-11-09 08:15:10
文档

通过XtraBackup实现不停机不锁表搭建MySQL主从同步

通过XtraBackup实现不停机不锁表搭建MySQL主从同步:Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时,X Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时
推荐度:
导读通过XtraBackup实现不停机不锁表搭建MySQL主从同步:Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时,X Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时

Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时,X

Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时,Xtrabackup 会将 Master 的 binlog 信息记录在 xtrabackup_slave_info 文件中,通过此信息可以方便的搭建主从复制。

XtraBackup 有两个工具:xtrabackup 和 innobackupex:

  • xtrabackup 本身只能备份 InnoDB 和 XtraDB ,不能备份 MyISAM;
  • innobackupex 本身是 Hot Backup 脚本修改而来,同时可以备份 MyISAM 和 InnoDB,但是备份 MyISAM 需要加读锁。
  • 官网:
    文档:

    注:本文服务器环境为 CentOS,其他环境请自行修改实现。

    修改主库、从库 MySQL 配置文件

    1、Master

    vim /etc/my.cnf

    2、Slave:

    vim /etc/my.cnf

    server-id=2 datadir=/var/lib/mysql 安装 XtraBackup 1、添加源

    yum install

    检查是否添加成功:

    yum list | grep percona

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

    percona-release.x86_64 0.0-1 installed ... Percona-.rhel5 percona Percona-.rhel5 percona Percona-.rhel5 percona Percona-.rhel5 percona Percona-.rhel5 percona ... xtrabackup.x86_64 1.2-22.rhel5 percona 2、安装 xtrabackup

    yum install percona-xtrabackup

    创建备份

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

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

    innobackupex: Backup created in directory '/path/to/BACKUP-DIR/2015-03-03_00-00-09' innobackupex: MySQL :00:53 innobackupex: completed OK!

    备份时,innobackupex 会调用 xtrabackup 备份 InnoDB 表的数据,并且会复制 MyISAM, MERGE,,CSV 和 ARCHIVE 表的表定义文件(.frm 文件)、数据文件。同时还会备份触发器和数据库配置信息相关的文件。这些文件将会保存在指定备份目录中一个以时间戳命名的目录下。

    准备备份

    一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据文件仍处理不一致状态。“准备”的主要作用正是通过回滚未提交的事务及同步已经提交的事务至数据文件也使得数据文件处于一致性状态。

    innobackupex --apply-log /path/to/BACKUP-DIR

    如果执行正确,其最后输出的几行信息通常如下:

    xtrabackup: starting :01:36 InnoDB: Starting shutdown... 09:01:40 innobackupex: completed OK!

    在实现“准备”的过程中,innobackupex 通常还可以使用 --use-memory 选项来指定其可以使用的内存的大小,默认通常为 100M。如果有足够的内存可用,可以多划分一些内存给 prepare 的过程,以提高其完成速度。

    恢复备份

    将数据复制到从服务器上:
    scp -r /path/to/BACKUP-DIR root@slave_host:/data/

    在从服务器中恢复备份数据:
    innobackupex --copy-back /path/to/BACKUP-DIR

    如果服务器剩余空间不足,你可以使用 --move-back 替换掉 --copy-back。

    如果执行正确,其输出信息的最后几行通常如下:

    innobackupex: Starting to copy InnoDB log files innobackupex: in '/backup/2012-04-07_08-17-03' innobackupex: back to original InnoDB log directory '/mydata/data' innobackupex: Finished copying back files. ... 120407 09:36:10 innobackupex: completed OK! 启动从库 MySQL,设置主库信息

    当数据恢复至数据目录以后,还需要确保所有数据文件的属主和属组均为正确的用户,如mysql,否则,在启动mysqld之前还需要事先修改数据文件的属主和属组。如:

    chown -R mysql:mysql /mydata/data/

    启动从库:

    /etc/init.d/mysqld start

    在主库中开设主从用的账号和权限:

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

    查看备份文件 xtrabackup_binlog_info 中的日志文件以及position。

    MASTER_HOST='', MASTER_USER='', MASTER_PASSWORD='', MASTER_LOG_FILE='', MASTER_LOG_POS=;

    开启主从同步:

    START SLAVE;

    查看从库状态:

    ;

    Ps:用 innobackupex 备份数据时,–apply-log 处理过的备份数据里有两个文件说明该备份数据对应的 binlog 的文件名和位置。但有时这俩文件说明的位置可能会不同。
    1 对于纯 InnoDB 操作,备份出来的数据中上述两个文件的内容是一致的
    2 对于 InnoDB 和非事务存储引擎混合操作,xtrabackup_binlog_info 中所示的 position 应该会比 xtrabackup_pos_innodb 所示的数值大。此时应以 xtrabackup_binlog_info 为准;而后者和 apply-log 时 InnoDB recovery log 中显示的内容是一致的,只针对 InnoDB 这部分数据。

    Ps2:启动 MySQL 时,遇到权限问题的解决方法:

    报错信息:

    : Operating system error number 13 in a file operation. InnoDB: The error means mysqld does not have the access rights to InnoDB: the directory.

    解决方法:
    chown -R mysql:mysql /home/data/mysql
    chcon -R -t mysqld_db_t /home/mysql

    参考资料:

    1、
    2、

    MySQL管理之使用XtraBackup进行热备

    MySQL开源备份工具Xtrabackup备份部署

    MySQL Xtrabackup备份和恢复

    用XtraBackup实现MySQL的主从复制快速部署【主不锁表】

    安装和使用 Percona 推出的 Xtrabackup 备份 MySQL

    XtraBackup 的详细介绍:请点这里
    XtraBackup 的下载地址:请点这里

    本文永久更新链接地址:

    声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

    通过XtraBackup实现不停机不锁表搭建MySQL主从同步

    通过XtraBackup实现不停机不锁表搭建MySQL主从同步:Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时,X Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top