首页 云数据库 OceanBase 操作指南 数据传输 数据迁移 迁移 OceanBase 数据库 Oracle 租户的增量数据至 MySQL 数据库

迁移 OceanBase 数据库 Oracle 租户的增量数据至 MySQL 数据库

更新时间: 2023-11-29 10:14:07

本文为您介绍如何使用数据传输迁移 OceanBase 数据库 Oracle 租户的增量数据至 MySQL 数据库。

重要

如果数据迁移项目长期处于非活跃状态(项目状态为 失败已暂停已完成),受增量日志保留时长等影响,项目可能无法恢复。数据传输将主动释放处于非活跃状态超过 7 天的数据迁移项目,以回收相关资源,建议您为项目配置告警并及时处理项目相关异常。

前提条件

  • 已购买传输实例。详情请参见 购买传输实例

  • 已为源端 OceanBase 数据库 Oracle 租户和目标端 MySQL 数据库创建专用于数据迁移项目的数据库用户,并为其赋予了相关权限。详情请参见 创建数据库用户

使用限制

  • 数据传输支持的 MySQL 数据库版本为 5.5、5.6、5.7 和 8.0 版本。

  • 数据传输不支持迁移 OceanBase 数据库 Oracle 租户的无主键表至 MySQL 数据库。

  • 目标端是数据库的情况下,数据传输不支持目标端存在 Trigger。如果存在,可能导致数据迁移失败。

  • 数据传输仅支持迁移库名、表名和列名为 ASCII 码且不包含特殊字符(包括换行、空格,以及 .|"'`()=;/&)的对象。

  • 数据传输不支持 OceanBase 备库作为源端。

注意事项

  • ​如果源端字符集为 UTF-8,建议目标端使用兼容源端的字符集(例如,UTF-8、UTF-16 等),避免产生因字符集不兼容导致目标端出现乱码等问题。

  • 节点之间的时钟不同步,或者电脑终端和服务器之间的时钟不同步,均可能导致延迟时间(增量同步/反向增量)不准确。

    例如,如果时钟早于标准时间,可能导致延迟时间为负数。如果时钟晚于标准时间,可能导致延迟。

  • OceanBase 数据库 Oracle 租户至 MySQL 数据库的数据迁移项目中,当 OceanBase 数据库 Oracle 租户为 3.2.x 以下的版本且具有全局唯一索引的多分区表时,如果您更新了表的分区键的值,可能导致数据迁移过程中丢失数据。

  • 如果您变更目标端的唯一索引,需要重启数据迁移项目,否则可能存在数据不一致的问题。

  • 通过配置匹配规则的方式选择 CTAS 语句创建的表作为迁移对象时,建议您提前设置特定的规则(例如,a.*_2023_backup)来避免出现数据迁移项目中断的情况。

  • 如果源端和目标端的表结构不完全一致,可能会出现数据不一致的情况。目前已知场景如下:

    • 用户手动创建表结构时,因超出数据传输的支持范围,可能产生隐式的转换问题导致源端和目标端列的类型不一致。

    • 目标端的数据长度小于源端的数据长度时,可能出现数据截断的情况,导致源端和目标端的数据不一致。

支持的源端和目标端实例类型

下表中,OceanBase 数据库 Oracle 租户简称为 OB_Oracle,支持的实例类型为 OceanBase 集群实例。

源端

目标端

OB_Oracle

MySQL(RDS 实例)

OB_Oracle

MySQL(PolarDB 实例)

OB_Oracle

MySQL(VPC 内自建数据库)

OB_Oracle

MySQL(数据库网关)

OB_Oracle

MySQL(公网 IP 自建数据库)

操作步骤

  1. 新建迁移项目。

    1. 登录 OceanBase 管理控制台

    2. 在左侧导航栏,单击 数据传输>数据迁移

    3. 数据迁移 页面,单击右上角的 新建迁移项目

  2. 选择源和目标 页面,配置各项参数。

    参数

    描述

    迁移项目名称

    建议使用中文、数字和字母的组合。名称中不能包含空格,长度不能超过 64 个字符。

    标签

    单击文本框,在下拉列表中选择目标标签。您也可以单击 管理标签,进行新建、修改和删除。详情请参见 通过标签管理数据迁移项目

    源端

    如果您已新建 OceanBase 数据库 Oracle 租户数据源,请从下拉列表中进行选择。如果未新建,请单击下拉列表中的 新建数据源,在右侧对话框进行新建。参数详情请参见 新建 OceanBase 数据源

    重要

    源端仅支持 OceanBase 数据库 Oracle 租户的 实例类型OceanBase 集群实例

    目标端

    如果您已新建 MySQL 数据源,请从下拉列表中进行选择。如果未新建,请单击下拉列表中的 新建数据源,在右侧对话框进行新建。参数详情请参见 新建 MySQL 数据源

    传输实例

    从下拉列表中选择已购买的传输实例。如果您未购买,请单击右侧的 购买 进行操作。详情请参见 购买传输实例

  3. 单击 下一步。在 选择迁移类型 页面,选择当前迁移项目的迁移类型。

    目前仅支持 增量同步 中的 同步 DML,详情请参见 DML 过滤

  4. 单击 下一步。在 选择迁移对象 页面,选择迁移对象。

    您可以通过 指定对象匹配规则 两个入口选择迁移对象。

    重要
    • 待迁移的表名和其中的列名不能包含中文字符。

    • 当数据库的库名或表名存在“$$”字符时,会影响数据迁移项目的创建。

    • 选择 指定对象,在左侧选中需要迁移的对象,单击 >,将其添加至右侧列表中。您可以选择一个或多个库的表、视图作为迁移对象。

      数据传输支持通过文本导入对象,并支持对目标端对象进行重命名、设置行过滤、查看列信息,以及移除单个或全部迁移对象等操作。

      操作

      步骤

      导入对象

      1. 在选择区域的右侧列表中,单击右上角的 导入对象

      2. 在对话框中,单击 确定

        重要

        导入会覆盖之前的操作选择,请谨慎操作。

      3. 导入迁移对象 对话框中,导入需要迁移的对象。

        您可以通过导入 CSV 文件的方式进行库表重命名、设置行过滤条件等操作。详情请参见 下载和导入迁移对象配置

      4. 单击 检验合法性

        完成迁移对象导入后,请先检验合法性。目前暂不支持列字段映射。

      5. 通过检验后,单击 确定

      重命名

      数据传输支持重命名迁移对象的名称,详情请参见 数据库库表重命名

      设置

      数据传输支持 where 条件实现行过滤,详情请参见 SQL 条件过滤数据

      您还可以在 查看列 区域,查看迁移对象的列信息。

      移除/全部移除

      数据传输支持在数据映射时,对暂时选中到目标端的单个或多个对象进行移除操作。

      • 移除单个迁移对象

        在选择区域的右侧列表中,鼠标悬停至目标对象,单击显示的 移除,即可移除该迁移对象。

      • 移除全部迁移对象

        在选择区域的右侧列表中,单击右上角的 全部移除。在对话框中,单击 确定,即可移除全部迁移对象。

    • 选择 匹配规则,详情请参见 配置迁移对象的匹配规则

  5. 单击 下一步。在 迁移选项 页面,配置各项参数。

    参数

    描述

    实例规格

    展示所选传输实例的规格,不支持修改。

    增量同步起始位点

    请在此处指定迁移某个时间节点之后的数据,默认为当前系统时间。详情请参见 设置增量同步位点

  6. 单击 预检查,系统对数据迁移项目进行预检查。

    预检查 环节,数据传输会检查数据库用户的读写权限、数据库的网络连接等是否符合要求。全部检查项目均通过后才能启动数据迁移项目。如果预检查报错:

    • 您可以在排查并处理问题后,重新执行预检查,直至预检查成功。

    • 您也可以单击错误预检查项操作列中的 跳过,会弹出对话框提示您跳过本操作的具体影响,确认可以跳过后,请单击对话框中的 确定

  7. 预检查成功后,单击 启动项目

    如果您暂时无需启动项目,请单击 保存。后续您只能在 迁移项目列表 页面手动启动项目或通过批量操作启动项目。批量操作的详情请参见 批量操作数据迁移项目

    数据传输支持在数据迁移项目运行过程中修改迁移对象,详情请参见 查看和修改迁移对象。数据迁移项目启动后,会根据选择的迁移类型依次执行,详情请参见 查看迁移详情

相关文档

阿里云首页 云数据库 OceanBase 相关技术圈