分库分表,数据库分库分表思路
SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。
扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄
迁移到分库分表方式
一般来说,会有三种方式:
- 1、停止部署法。
- 2、双写部署法,基于业务层。
- 3、双写部署法,基于 binlog 。
具体的详细方案,可以看看如下两篇文章:
分库分表后数据迁移问题
- 双写 以老库为主。读操作还是读老库老表,写操作是双写到新老表。
- 历史数据迁移 dts + 新数据对账校验(job) + 历史数据校验。
- 切读:读写以新表为主,新表成功就成功了。
- 观察几天 下掉写老库操作。
分布式事务解决
目前市面上,分布式事务的解决方案还是蛮多的,但是都是基于一个前提,需要保证本地事务。那么,就对我们在分库分表时,就有相应的要求:数据在分库分表时,需要保证一个逻辑中,能够形成本地事务。举个例子,创建订单时,我们会插入订单表和订单明细表,那么:
- 如果我们基于这两个表的 id 进行分库分表,将会导致插入的记录被分到不同的库表中,因为创建下单可以购买 n 个商品,那么就会有 1 条订单记录和 n 条 订单明细记录。而这 n 条订单明细记录无法和 1 条订单记录分到一个库表中。
-
如果我们基于这两个表的 user_id 进行分库分表,那么插入的记录被分到相同的库表中。

更多精彩