Xtrabackup导致主从延时问题

背景问题

公司数据库备份采用Xtrabackup, 备份期间会导致数据库实例产生主从延时,增加数据库告警数量。而且数据库主从延时会影响数据访问的准确性,延时期间如果主库发生故障,会有数据丢失的风险;延时也可能影响抽数等相关任务;

原因分析:Xtrabackup备份完idb数据文件后,执行FLUSH TABLES WITH READ LOCK(FTWRL),取得一致性位点,然后开始备份非InnoDB文件(如frm、MYD、MYI、CSV、opt、par等格式的文件),在拷贝非InnoDB文件的过程当中,数据库处于全局只读状态,直到非InnoDB文件备份完毕后释放;

参数说明

默认参数

FTWRL ,它有两个作用,

1:将打开的表关闭,并将内存中的脏数据刷到硬盘,从而保证数据的一致性;

2:获取全局读锁,阻塞其他线程的写操作,从而确保备份过程中数据不被修改;

--lock-ddl:

采用"LOCK TABLES FOR BACKUP",参数的作用是在整个备份过程中获取全局的元数据锁(MDL),以阻止所有 DDL 操作。这意味着当使用此参数时,任何尝试对数据库进行 DDL 操作(如 ALTER TABLE、CREATE TABLE 等)的线程都将被阻塞,直到备份完成并释放 MDL 锁。

FTWRL 和LOCK TABLES FOR BACKUP 区别

1,范围:FTWRL锁定所有表,包括事务性和非事务性的;LOCK TABLES FOR BACKUP主要锁定非事务性的表。

2, 阻塞: FTWRL会阻塞所有表的更新操作,LOCK TABLES FOR BACKUP只阻塞非事务表的更新操作;

3, LOCK TABLES FOR BACKUP

--lock-ddl-per-table

参数的作用是为每个备份的表单独获取 MDL 锁。这意味着备份工具会针对每个非 InnoDB 表单独加锁,而不是在整个备份过程中加全局锁。这种方式可以减少对数据库操作的阻塞,因为不是所有的 DDL 操作都会被阻塞,只有那些针对正在备份的表的 DDL 操作才会被阻塞,从而降低对数据库延时的影响;

--lock-ddl-per-table备份过程日志如下,日志中可以看到,备份每张表的时候都单独添加MDL锁

240313 12:49:27 Locking MDL for mysql.plugin
240313 12:49:27 [01] Copying ./mysql/plugin.ibd to /export/data/dbbak/localbackup/mysql/plugin.ibd
240313 12:49:27 [01]        ...done
240313 12:49:27 Locking MDL for mysql.servers
240313 12:49:27 [01] Copying ./mysql/servers.ibd to /export/data/dbbak/localbackup/mysql/servers.ibd
240313 12:49:27 [01]        ...done
240313 12:49:27 Locking MDL for mysql.help_topic
240313 12:49:27 [01] Copying ./mysql/help_topic.ibd to /export/data/dbbak/localbackup/mysql/help_topic.ibd
240313 12:49:27 [01]        ...done
240313 12:49:27 Locking MDL for mysql.help_category

功能测试

下面测试对比xtrabackup默认备份方式和 --lock-ddl-per-table方式 对备份延时,备份时长的影响;

备份方式

FTWRL

lock-ddl-per-table 第1次

lock-ddl-per-table 第2次

lock-ddl 第1次

lock-ddl 第2次

备份节点

xx,xx,xx,xx

xx,xx,xx,xxxx,xx,xx,xxxx,xx,xx,xxxx,xx,xx,xx

节点配置

8c 24576M

8c 24576M

8c 24576M

8c 24576M

8c 24576M

落盘方式

云盘

云盘

云盘

云盘

云盘

备份数据量

295GB

295GB

295GB

295GB

295GB

开始时间

3/13 15:26

3/13 15:26

3/13 16:37

3/13 20:13

3/13 20:20

结束时间

3/13 16:06

3/13 16:08

3/13 17:20

3/13 21:04

3/13 21:10

备份时长

40min

42min

43min

51min

50min

备份产生延时

114s

0

0

115s

120s

结论

1, 通过使用lock-ddl-per-table功能,会解决备份延时问题;

2, 相较于默认FTWRL方式,lock-ddl-per-table和lock-ddl备份时间会有些延长,如果个别业务在特定时间有大数据任务,要多加留意,避免备份时间延长从而影响抽数任务完成时间,进而影响上下游相关任务

  • 21
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
主从复制是MySQL数据库中常用的高可用性和数据备份方案之一。XtraBackup是Percona开发的一个开源工具,可以实现MySQL数据库的在线备份和恢复。 下面是搭建XtraBackup主从复制的大致步骤: 1. 确保主服务器和从服务器上都已经安装了MySQL数据库,并且版本一致。 2. 在主服务器上进行备份,可以使用XtraBackup进行在线备份。具体的备份命令可以参考XtraBackup的官方文档。 3. 将备份文件传输到从服务器上,可以使用scp或者其他文件传输工具进行传输。 4. 在从服务器上进行恢复,可以使用XtraBackup进行在线恢复。具体的恢复命令可以参考XtraBackup的官方文档。 5. 配置主服务器和从服务器的MySQL配置文件,开启二进制日志(binlog)和配置主从复制相关的参数。具体的配置可以参考MySQL的官方文档。 6. 在主服务器上创建一个用于复制的用户,并给予相应的权限。 7. 在从服务器上配置主从复制,使用CHANGE MASTER TO语句指定主服务器的位置和复制用户的凭据。 8. 启动从服务器上的复制进程,使用START SLAVE语句启动复制进程。 9. 检查主从复制状态,可以使用SHOW SLAVE STATUS命令来查看。 通过以上步骤,你可以成功搭建XtraBackup主从复制。请注意,这里只是一个简单的概述,具体的操作细节和配置参数还需要根据你的实际情况进行调整。建议你参考官方文档和相关的MySQL文档来获取更详细的信息和指导。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值