1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 通过 XtraBackup 实现不停机不锁表搭建MySQL主从同步

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

时间:2023-09-14 22:09:58

相关推荐

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

数据库|mysql教程

MySQL主从同步,XtraBackup,通过 XtraBa

数据库-mysql教程

那个源码论坛好,vscode使用教程web,ssd ubuntu系统,点了tomcat没反应,sqlite3数据库放在哪,武汉 爬虫,php 旅行社,郑州360 seo优化推广,什么网站可以留言,oa协同办公管理模板lzw

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

诗词大全源码,vscode可以写javaee,ubuntu窗口调整,ps 没有tomcat,采用SQlite数据库原因,爬虫内容如何以jaon形式存储,php调用jar,北京seo营销哪家好,建材企业网站模板,超炫网页设计,怎么替换dede模板lzw

搞笑类网站cms源码,ubuntu改tl值,tomcat8启动不成功,python爬虫搜索软件,php如何进行用户权限管理,地产seo专家lzw

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/f

2、Slave:

vim /etc/f

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/-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/-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 的下载地址:请点这里

本文永久更新链接地址:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。