前言

数据迁移时, 为了保证数据的一致性, 往往伴随着停服, 此期间无法给用户提供服务或只能提供部分服务. 同时, 为了确保迁移后业务及数据的正确性, 迁移后测试工作也要占用不少时间. 如此造成的损失是比较大的.

接下来, 本文将就如何在不停服的情况下进行数据迁移进行探讨.

案例

订单系统中存在这样一组订单表:

数据库: MySQL

表名: order_{0~19}, 其中{0~19}为后缀, 合共20张表.

主键: order_id, 订单ID, 通过雪花算法获得, 可通过ID获取创建时间.

原分表策略: order_id % 20

伴随着业务量增长, 各分表的数据量已经破千万, 如此下去会产生严重的性能问题, 此时需要将原分表进行迁移.

要求:

将原20张分表数据迁移至新表

迁移全过程中不可停机, 须对外提供完整的服务.

提供完备的回退方案, 迁移过程中产生的数据不可丢, 不能人为修数据.

分析

有过分库分表经验的读者可能已经发现案例中原分表策略十分不合理, 其缘由不去追究(毕竟换了几波人之后已经没办法找到当年的人吊起来揍了).

分析一下原数据表: 订单数据肯定会伴随着时间和业务量直线上升, 固定的分表数量会导致随数据量增大性能下降. 所以, 数据迁移后, 分表的数量不能再固定, 即使从20改成100个总有一天也会达到瓶颈.

订单数据会伴随时间增长, 而且在超过退款期限后就变成了冷数据, 使用率会降低. 因此, 将订单按照创建时间来进行分表是一个不错的选择. 值得一提的是, order_id是通过雪花算法获得, 可以从order_id中获取创建时间, 可以通过order_id直接获取分片键.

迁移方案分析

数据迁移的方案从业务层到数据库层各有不同的迁移方案, 我们先列举一些进行比对:

业务层: 在业务层进行硬编码, 数据双写, 以某个时间点进行划分, 新产生的数据同时写入新表, 运行一段时间后将旧数据迁移至新表. 成本极高, 与业务耦合严重, 不考虑.

连接层: 是方案1的进阶版, 在连接层拦截SQL进行双写, 与业务解耦, 但与1有着同样的一个问题: 周期较长, 要确保旧数据不会产生变更才能进行迁移.

触发器: 通过触发器将新产生的数据同步到新表, 本质上与2差不多.

数据库日志: 从某一时间点T备份数据库, 将备份库的数据迁移至新表, 从时间点T读取日志, 恢复到新表, 并持续写入. 待两份数据保持同步后, 上线新代码.

伪装从库: 相对于方案4的优势是不需要直接去读取日志, 解决了数据库在云上不方便直接读取日志的问题.

相比较之下, 方案4和5都是可选的, 因数据库在云上, 直接读取日志不方便, 且方案5有成熟的开源中间件**canal**可用, 故笔者选择了方案5.

回退方案分析

新代码上线后, 谁也不能确保百分百没问题. 若迁移失败, 必须要进行回滚. 所以, 需要保证原数据和新数据的同步.

所以, 在前一小节方案5的基础上, 切流量到新集群后, 我们停止数据同步, 从切流量时刻开始同步新表数据到旧表, 方案也是伪装从库. 如此就能保证新旧表的数据同步, 如果上线后发生了异常, 将流量切回旧集群即可.

整体方案设计

备份源数据

执行flush logs: 生成新的binlog, 恢复数据将从这里开始.

备份数据表(order_{0~19}): 将源(旧)数据表从主库A复制到备份库B

恢复并同步数据

在主库A创建足够的新表, order新表按照月进行分表.

写脚本读取备份库B中的order表, 写入主库A的order新表.

通过canal开始同步旧表数据到新表, 命名为[同步过程-a].

上线

编译新代码并弹一个新的集群, 确认完全启动完成.

执行flush logs生成新的binlog, 新表向旧表同步数据将从这里开始.

流量切到新集群.

停止[同步过程-a].

开始从新表向旧表同步数据.

回退

上线后应及时进行测试, 一旦发现严重的异常就立即将流量切回旧集群.

结语

flash logs要先于备份源数据表, 即使中间有些许时间间隔也不会影响数据的最终一致 (听binlog的总没错).

数据无价, 谨慎操作.

如果这篇文章对您有帮助,请点个赞吧 ( ̄▽ ̄)"

推荐阅读

欢迎关注公众号(代码如诗)

[版权声明]

本文发布于朴瑞卿的博客, 允许非商业用途转载, 但转载必须保留原作者朴瑞卿 及链接:blog.piaoruiqing.com.

如有授权方面的协商或合作, 请联系邮箱: piaoruiqing@gmail.com.

mysql不停机迁移_不停服! 怎么迁移数据相关推荐

  1. mysql不停机迁移_不停业务,做mysql数据迁移。

    入职小美到家后,发现mysql-data目录存储在20G根目录磁盘,磁盘空间越来越小,这个坑必须填掉.同事要求不停业务做迁移,讨论后方案如下: 方案: 1.使用xtartbackup做mysql的ma ...

  2. 教育启蒙赛道、亿级异构数据不停服平滑迁移方案和实践

    背景 学前启蒙教育赛道,竞争日益激励,好未来集团旗下"小猴英语","小猴语文","小猴思维"三条独立产品站线,战略调整,资源合并,重拳出击, ...

  3. neo4j 迁移_在Kubernetes中迁移Neo4j图模式

    neo4j 迁移 在零停机时间下运行企业应用程序时,我们需要能够执行数据库架构迁移而又不中断活动用户. 这不仅对于关系数据库很重要,而且对于诸如Neo4J之类的图数据库也很重要,后者不会在write上 ...

  4. mysql 日期区间创建_按日期范围统计数据

    第一步:mysql使用存储过程,创建日历表 创建日历表: CREATE TABLE `capacity_common_date` ( `ID` int(11) NOT NULL AUTO_INCREM ...

  5. cnn风格迁移_快速图像风格迁移思想在无线通信中的另类应用:算法拟合

    在本文中,并不是介绍最新的一些论文,而是回顾自己在很早(半年前?)读过的几篇文章.[1]Learning to optimize: Training deep neural networks for ...

  6. mysql dump 导入导出_使用mysqldump导入导出数据

    DRDS支持MySQL官方数据导出工具mysqldump.本文围绕DRDS数据导入导出的几种常见场景对操作步骤和注意事项进行说明.mysqldump命令的详细说明请参见MySQL官方文档. mysql ...

  7. jboss4 迁移_应用程序服务器迁移:从JBoss EE5到Wildfly EE7

    jboss4 迁移 几周前,我发布了一个有关从Java EE 5迁移到7的博客 .这主要是关于如何使用新的Java EE 7改进Java EE 5代码. 现在,在这篇文章中,我将对应用程序服务器端的迁 ...

  8. sqoop遇到mysql字段为保留字_关于在sqoop 导出数据到mysql数据库的过程对于空字符的处理。...

    今天在做sqoop的导入和导出的操作.在导出数据到mysql数据库的时候一直有问题,在导入空字段的时候就出现下面这个错误. WARN hdfs.DFSClient: Caught exception ...

  9. ecs硬盘数据迁移_阿里云ECS新增数据盘以及迁移数据方法

    第一.检查数据占用以及数据盘 我们从探针可以看到,本身有30GB的硬盘只用到不到10GB,而且系统和WDCP面板/网站都系统盘中. 通过fdisk -l 我们可以看到还有21GB的没有格式化和挂载,系 ...

最新文章

  1. 热更新 FrameWork
  2. android自定义弹框效果合集,android 自定义弹出框AlertDialog ,很炫的哦
  3. VS2012+LUA环境搭建
  4. [daily] 使用diff和patch打补丁
  5. Windows 1.0 to Windows 10
  6. [Bug] .NET 2.0 的Bug —— ComboBox中不能添加Component.
  7. pd.get_dummies()
  8. com.alibaba.fastjson.JSONObject cannot be cast to XXX异常解决
  9. drop sqlite 多个表_SQLite简介与安装
  10. code blocks c语言,Code Blocks安装与使用图文教程(使用Code::Blocks编写C语言程序)...
  11. 审计导致select * 报ORA-01435: user does not exist
  12. hibernate一对多映射实现
  13. python 读取excel失败 可以转换成csv文件
  14. leetcode-二叉树中的最大路径和
  15. Sci-Hub又又又被起诉了!这个论文免费下载网站也太难了...
  16. 电脑版微信多开小技巧
  17. html页眉页脚独立,word中怎样单独页面设置页眉
  18. 明朝经典战役\明朝挽救历史狂澜\于谦人生最高点\北京保卫战
  19. NodeJs C++ addon(插件nan方式)
  20. Laravel 第十章 API测试和文档

热门文章

  1. 阿里云mysql空间清理
  2. 汇编语言显示“*”符号图案(1)
  3. python中求质数_python求质数的3种方法
  4. 爬取奇书网书籍信息并存入自动生成的xls表中(完善版)
  5. 【Axure教程】随机函数与抽签原型
  6. 阿里内部 Java 面试八股文出炉,教科书式完美回答
  7. java 热量图实现_安卓实现计步器,能够计算卡路里的消耗
  8. 秋招百度Android面经
  9. 最近面试高级前端工程师的一些感受
  10. 光纤收发器哪个发射,那个接收?