使用innobackup实现 基于GTID的从库搭建

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

对于较大的数据库,我们一般都是使用innobackup进行备份,备份的及恢复的速度更快。


试验环境:

  CentOS6.8 x86_64

  MySQL5.6.34 社区rpm版

  xtrabackup版本:percona-xtrabackup-24-2.4.5-1.el6.x86_64.rpm

  主库:node0 192.168.2.10 (需要安装xtrabackup和lz4)

  从库:node1 192.168.2.11(需要安装xtrabackup和lz4)


5.6下GTID复制必须配的参数(主库和从库都要加上这3行参数):

  gtid-mode=ON

  enforce_gtid_consistency = ON

  log_slave_updates=ON



step1、在从库创建备份文件的存放目录:

mkdir /tmp/db_restore


step2、在主库执行备份(最好开个screen操作,防止网络中断的问题),直接导出到从库机器上:

## 注意这里我们还需要提前在2台机器上安装lz4压缩工具,因为我们的脚本会调用lz4压缩和解压备份文件

innobackupex --user=root \

--password=123456  \

--parallel=4 \

--socket=/tmp/mysql.sock \

--no-timestamp \

--stream=xbstream . |\

lz4 -B4 |\

ssh node1 \

"cat - | lz4 -d -B7 | xbstream -x -C /tmp/db_restore"



step3、在从库node1上看下 主库的gtid位置

cd /tmp/db_restore

cat  xtrabackup_binlog_info 内容如下:

mysql.000008       1949     013bfb27-2edd-11e7-89c7-000c296a2c0d:1-72


为了便于理解,我们去主库查看下对应时间段的binlog,截图如下:

wKiom1kJtfuSNDejAADMrDq3FGI097.png

补充:xtrabackup_binlog_info内容解读:

mysql.000008 表示主库的binlog文件名,1949是尚未执行的binlog position(就是说我们使用传统change master模式的时候MASTER_LOG_FILE='master2-bin.001',MASTER_LOG_POS=1949)。

013bfb27-2edd-11e7-89c7-000c296a2c0d:1-72 指的是已经执行完的GTID编号(就是说我们change master的时候需要先执行set global gtid_purged='013bfb27-2edd-11e7-89c7-000c296a2c0d:1-72';   来purge掉这些GTID)。


step4、在从库上将上一步获取到的这些gtid purge掉,因为这些实际上已经执行过了。

set global gtid_purged='013bfb27-2edd-11e7-89c7-000c296a2c0d:1-72';    

如果提示 ERROR 1840 (HY000): @@GLOBAL.GTID_PURGED can only be set when @@GLOBAL.GTID_EXECUTED is empty. 则需要执行下reset master;


step5、配置并启动复制:

CHANGE MASTER TO MASTER_HOST='192.168.2.10', 

 MASTER_USER='rpl', 

 MASTER_PASSWORD='rpl', 

 MASTER_PORT=3306, 

 MASTER_AUTO_POSITION=1;

 

start slave;

show slave status\G


然后可以在主库的test库下尝试创建几个表,验证下复制是否正常。



待确认的问题:

对于某些版本的innobackup,备份出的xtrabackup_binlog_info 里面只有mysql.000008  1949 ,而不带GTID编号。那么我们执行purge的时候就要根据binlog pos 1949这个位置到主库的binlog去找到它上一个的gtid编号(例如上图的就是013bfb27-2edd-11e7-89c7-000c296a2c0d:72)。或者使用传统模式的复制,不用GTID复制即可。










本文转自 lirulei90 51CTO博客,原文链接:http://blog.51cto.com/lee90/1921079,如需转载请自行联系原作者
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
关系型数据库 MySQL
MySQL 5.7 基于GTID主从复制+并行复制+半同步复制
MySQL 5.7 基于GTID主从复制+并行复制+半同步复制
168 0
|
关系型数据库 MySQL
MySQL 5.7 基于 GTID 主从复制 + 并行复制 + 半同步复制
MySQL 5.7 基于 GTID 主从复制 + 并行复制 + 半同步复制
629 0
|
关系型数据库 MySQL 数据库
基于GTID搭建主从MySQL
想让主从之间使用gtid的方式同步数据,需要我们在配置文件中开启mysql对gtid相关的配置信息 找到my.cnf ,在mysqld模块中加入如下的配置。(主库从库都这样)
189 0
|
关系型数据库 MySQL 数据库
【愚公系列】2022年04月 Mysql数据库-GTID同步
【愚公系列】2022年04月 Mysql数据库-GTID同步
233 0
|
SQL 关系型数据库 MySQL
MySQL5.7配置GTID双主
MySQL5.7配置GTID双主
|
关系型数据库 MySQL 数据库连接
MySQL一主多从复制(基于GTID)
宿主机环境下,运行多个MySQL,实现数据的主从复制
MySQL一主多从复制(基于GTID)
mysql5.7 gtid主从复制
mysql5.7 gtid主从复制配置
291 0
|
SQL 监控 关系型数据库
gtid主从复制原理和报错解决
mysql,gtid,主从复制
3483 0