MySQL表迁移

在互联网应用中需求快速迭代,很多时候可能需要对DB进行变更操作,例如增删字段,当然一般来说不会删除字段,因为这存在极大的风险,相比较添加字段风险会小很多,但是也要注意避开流量高峰进行操作,因为虽然MySQL5.6之后支持Online DDL一般情况不会锁表,但是对于大数据量的字段仍然会存在锁表风险,因此需要注意。


此次我遇到的是新老表主子分表的迁移问题。

  • 主要迁移的背景是:

老表的字段不够通用,很难覆盖多个场景,分表字段不合理存在而己分表。这两个条件导致需要迁移到新的表。
迁移的思路基本上就是先保证新老表双写
Id采用了公用一个表来自增,保证新表与老表的逻辑字段一致.
重新分表后新表的唯一键不存在冲突,例如老表的id在新表不能哈希到一张表。
最后开关切换读写新表,并替换到后面新的模型。到后面所有场景都验证过后,就可以下线新表了。
如果历史数据是有意义的,还需要写个定时任务去同步历史数据.同步完毕才能读新表。最好能灰度发布,充分验证。

  1. 读写老表
    在这里插入图片描述
    2.双写
    在这里插入图片描述

3.同步历史数据
在这里插入图片描述</

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值