mysql DDL可重入讨论

mysql的bug:当执行 MySQL online DDL 时,期间如有其他并发的 DML 对相同的表进行增量修改,比如 update、insert、insert into … on duplicate key、replace into 等,且增量修改的数据违背唯一约束,那么 DDL 最后都会执行失败,报错主键冲突。

这里的“增量修改的数据违背唯一约束”,从实践来看即使insert into on duplicate执行成功,依然有可能触发DDL报错,并非一定要DML执行失败。

参考:

https://blog.youkuaiyun.com/Tony_stark_L/article/details/127596879

解决方案:

  • 重试DDL
  • 使用第三方工具 pt-osc 或者 gh-ost 执行在线 DDL
  • 在 DDL 语句中指定 ALGORITHM=COPY,但该过程中只允许查询,不允许写入

方案2要引入额外的工具,方案3的话mysql内部要新建临时表,多占一倍空间,且改表结构时不能写入对业务影响也较大。

故选择方案1,建议确保DDL是可重入的,可以做工具完成DDL的可重入检查。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值