MySQL 主从同步延时问题

本文讨论了MySQL主从同步导致的线上故障,特别是在写并发高达2000/s时出现的数据延迟问题。当从库延迟几十毫秒时,可能会导致数据更新失败。解决方案包括分库减小主库压力、开启并行复制、优化代码避免即时查询和直接连接主库(不推荐),以保持读写分离的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以前线上确实处理过因为主从同步延时问题而导致的线上的 bug,属于小型的生产事故。 是这个么场景。

案例: 先插入一条数据,再把它查出来,然后更新这条数据。在生产环境高峰期,写并发达到 了 2000/s,这个时候,主从复制延时大概是在小几十毫秒。线上会发现,每天总有那么一些数据,我们期望更新 一些重要的数据状态,但在高峰期时候却没更新。用户跟客服反馈,而客服就会反馈给我们。

我们通过 MySQL 命令: show status

查看 Seconds_Behind_Master,可以看到从库复制主库的数据落后了几 ms。 一般来说,如果主从延迟较为严 重,有以下解决方案: 1. 分库,将一个主库拆分为多个主库,每个主库的写并发就减少了几倍,此时主从延迟可以忽略不计。【此时 是主库的执行性能可能不好】

2. 打开 MySQL 支持的并行复制,多个库并行复制。如果说某个库的写入并发就是特别高,单库写并发达到了 2000/s,并行复制还是没意义。

3. 重写代码,写代码的同学,要慎重,插入数据时立马查询可能查不到。

4. 如果确实是存在必须先插入,立马要求就查询到,然后立马就要反过来执行一些操作,对这个查询设置直连 主库。不推荐这种方法,你要是这么搞,读写分离的意义就丧失了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiaoheiba_

创作不易:伸伸小手

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值