一个月后,我们又从 MySQL 双主切换成了主 - 从

本文讲述了从MySQL双主模式切换为主从模式的原因、过程和总结。双主模式遇到的问题包括主键冲突、同步失败等,最终选择了简化为一主一从以降低风险。文中介绍了简单方式的主从切换流程,包括停止从节点的Keepalived、设置只读模式、调整权限等步骤。
摘要由CSDN通过智能技术生成

一、遇到的坑

一个月前,我们在测试环境部署了一套 MySQL 高可用架构,也就是 MySQL 双主 + Keepalived 的模式。

在这一个月遇到了很多坑:

  • 因为两个 MySQL 节点都可以写入,极其容易造成主键重复,进而导致主从同步失败。

  • 同步失败后,Slave_SQL_Thread 线程就停了,除非解决了同步的错误,才能继续进行同步。

  • 同步失败的错误,不会只有一条记录有问题,往往是一大片的同步问题。

  • 两个节点互相缺少对方的数据。

  • 主从的同步延迟,切换到新主库后,数据不是最新。

  • 当出现不一致时,无法确定以哪个库为准。

造成上面问题的主要原因就是因为两个节点都支持写入 + 双主可以随时切换。

解决这种问题的方案有 改进自增主键的步长(影响未评估),使用 GTID 方案(未验证)。即使这样,双主同步的风险还是有,而且不同步后,如何处理是个大难题。

那么回到我们最初的想法:为什么会选择双主?

最开始的目的就是为了高可用。双主就是说有一台 MySQL 节点挂了,另外一台能够顶上,对于用户来说是无感的,给运维人员一定的缓冲时间来排查 MySQL 故障。另外老的主节点恢复后,不用改配置就能立即成为从节点。

经过这一个月的 MySQL 双主模式的试运行,最后我们还是决定切换到 MySQL 主 - 从模式。

双主模式就是两个节点即是主节点也是从节点,那我们现在切换到一主一从模式,就可以认为是

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值