文档首页/ 数据复制服务 DRS/ 常见问题/ 通用操作/ 多对一的场景约束及操作建议
更新时间:2024-09-24 GMT+08:00

多对一的场景约束及操作建议

因业务需要,不同实例、不同表的数据需要进行合并时,数据复制服务提供的数据迁移和实时同步均支持多对一的场景。

多对一场景分为实例级多对一和库表级多对一。其中实例级多对一可创建多个同步任务实现;库表级多对一仅实时同步支持,通过实时同步的对象名映射功能,实现库级或者表级数据多对一同步。

操作建议

  • 为避免创建任务过程中出现空间不足问题,建议提前计算源数据库的数据量总和,根据该总和一次性规划目标实例的磁盘空间,剩余磁盘空间需大于源库实际数据量大小的总和(例如“源系统1”数据量大小为1GB,“源系统2”数据量大小为3GB,“源系统3”数据量大小为6GB,则目标实例的剩余磁盘空间应该大于10GB)。
  • 对于MySQL引擎,目标端参数的设置需要考虑整体资源的提升,建议使用第一个任务的参数对比功能中“常规参数”“一键修改”(其中max_connections除外),而“性能参数”应该结合目标端实际规格做相应的手工设置。
  • 对于多对一同步任务场景,由于该场景是一个一个任务逐步创建的,后面创建任务时可能会造成已创建任务的同步阻塞,为了避免这个情况发生,请注意创建技巧。 每个同步任务都会涉及创建索引步骤,而创建索引时数据库可能会导致Schema锁进而阻塞Schema下的其他表的数据同步,从而导致后创建的任务可能在索引创建阶段对已经同步中的任务阻塞一段时间,我们可以选择在创建同步任务最后设置为“稍后启动”,这样设定在业务低峰期后创建任务,从而避免后创建任务的索引创建对已有任务的同步阻塞。
  • 对于多对一同步任务场景,不建议使用内容对比,因为内容对比无法保证一致性。
  • 如果涉及表级汇集的多对一同步任务,则不支持DDL,否则会导致同步全部失败。
    图1 参数对比

场景一:实例级多对一数据迁移

数据迁移是以整体数据库搬迁为目的,可以实现实例级多对一迁移(如图2,源1、2、3中的数据到目标库的迁移),不支持源端具有同名的数据库,不支持库名映射。

图2 多对一数据迁移

场景二:多对一实时同步

实时同步不同于数据迁移,是维持不同业务之间的数据持续性流动,除了可以实现实例级多对一同步(如图3,财务系统、订单系统到报表系统的数据同步)外,还可以通过对象名映射功能,实现库级或者表级数据多对一同步(如图3,财务系统、订单系统中表B的数据到报表系统表B的数据同步)。

图3 多对一实时同步

实例级多对一任务操作流程

创建任务时,为方便多对一任务间的相互识别,请在创建顺序上确保第一个任务进入全量迁移后再创建第二个任务,具体操作请参见:方案概览

图4 操作流程

库表级多对一任务操作流程

实时同步过程中,可以使用对象名映射功能修改库、表名称,实现库表级多对一。

以库级多对一为例:

  1. “设定同步”页面,同步对象右侧已选对象框中,选择需要进行映射的数据库,单击“编辑”按钮。
  2. “编辑库名”的弹出框中,填写新的数据库名,修改后的名称即为保存在目标数据库中的库名。

    例如,将源库中的库A和库B,修改为同样的库C后,即可实时库A、库B到库C的同步。

  3. 库名修改成功后,您会看到修改前的库名和修改后的新数据库名,至此,表示完成库映射的配置。

    图5 查看库名修改结果

  4. 配置完成后,等待任务启动并完成同步。