本文介绍如何使用数据传输服务DTS(Data Transmission Service),将自建MySQL迁移至MyBase MySQL。DTS支持结构迁移、全量数据迁移以及增量数据迁移,同时使用这三种迁移类型可以实现在自建应用不停服的情况下,平滑地完成自建MySQL数据库的迁移上云。
本文是以新版数据传输服务DTS(Data Transmission Service)控制台为例,旧版数据传输服务DTS(Data Transmission Service)控制台自建MySQL迁移至MyBase MySQL的操作,请参见从自建MySQL迁移至MyBase MySQL。
前提条件
-
自建MySQL数据库版本为5.1、5.5、5.6、5.7或8.0版本。
- 已创建目标数据库实例。具体操作,请参见创建MyBase MySQL实例。
- 实例的存储空间须大于自建MySQL数据库占用的存储空间。
- 如果您的MySQL数据库部署在本地,那么您需要将DTS服务器的IP地址设置为该数据库远程连接的白名单,允许其访问您的数据库。详情请参见添加DTS服务器IP地址白名单。
支持的源和目标数据库
MySQL间迁移支持以下源或目标数据库。本文以ECS自建数据库为源数据库,MyBase MySQL实例为目标数据库介绍配置流程,其他数据源配置流程与本案例类似。| 源数据库 | 目标数据库 |
|
|
注意事项
| 类型 | 说明 |
| 源库限制 |
|
| 其他限制 |
|
| 特殊情况 |
|
费用说明
| 迁移类型 | 链路配置费用 | 公网流量费用 |
| 结构迁移和全量数据迁移 | 不收费。 | 通过公网将数据迁移出阿里云时将收费,详情请参见计费概述。 |
| 增量数据迁移 | 收费,详情请参见计费概述。 |
迁移类型说明
库表结构迁移
DTS将源库中迁移对象的结构定义迁移到目标库。
目前DTS支持结构迁移的对象为表、视图、触发器、存储过程和函数。
说明不会修改存储过程的
routine_body、函数的routine_body、视图的select_statement。在库表结构迁移时,DTS会将待迁移视图、存储过程和函数中的DEFINER转换为INVOKER(即将安全验证方式SQL SECURITY的值转换为INVOKER),并将定义者(DEFINER)设置为迁移任务中使用的目标库账号。
说明不会修改源库的安全验证方式和定义者。
由于DTS不迁移USER信息,因此在调用目标库的视图、存储过程和函数时,需要对调用者授予读写权限。
全量迁移
DTS将源库中迁移对象的存量数据,全部迁移到目标库中。
增量迁移
DTS在全量迁移的基础上,将源库的增量更新数据迁移到目标库中。通过增量数据迁移可以实现在自建应用不停机的情况下,平滑地完成数据迁移。
支持增量迁移的SQL操作
操作类型 | SQL操作语句 |
DML | INSERT、UPDATE、DELETE |
DDL |
|
数据库账号的权限要求
| 数据库 | 库表结构迁移 | 全量迁移 | 增量迁移 |
| ECS自建MySQL数据库 | SELECT权限 | SELECT权限 | 增量数据迁移:待迁移对象的SELECT权限 REPLICATION CLIENT、REPLICATION SLAVE、SHOW VIEW |
| MyBase MySQL实例 | 读写权限 | ||
数据库账号创建及授权方法:
- 自建MySQL数据库请参见为自建MySQL创建账号并设置binlog。
- MyBase MySQL实例请参见创建数据库账号和变更数据库账号。
操作步骤
- 说明
您也可以登录DMS数据管理服务。在顶部菜单栏中,选择。
在页面左上角,选择迁移实例所属地域。
- 单击创建任务,配置源库及目标库信息。
警告
选择源和目标实例后,建议您仔细阅读页面上方显示的使用限制,否则可能会导致任务失败或数据不一致。
类别 配置 说明 无 任务名称 DTS会自动生成一个任务名称,建议配置具有业务意义的名称(无唯一性要求),便于后续识别。 源库信息 选择已有的实例 您可以按实际需求,选择是否使用已有实例。
如使用已有实例,下方数据库信息将自动填入,您无需重复输入。
如不使用已有实例,您需要输入下方的数据库信息。
数据库类型 选择MySQL。 接入方式 根据源库的部署位置进行选择,本文以ECS自建数据库为例介绍配置流程。 实例地区 选择源MySQL数据库所属地域。 ECS实例ID 选择所需要迁移数据的ECS实例。 端口 填入源MySQL数据库的服务端口(需开放至公网),默认为3306。 数据库账号 填入源MySQL数据库的账号,权限要求请参见数据库账号的权限要求。 数据库密码 填入该数据库账号对应的密码。
连接方式 根据数据安全要求选择非加密连接或SSL安全连接,本文以非加密连接为例介绍配置流程。 目标库信息 选择DMS数据库实例 您可以按实际需求,选择是否使用已有实例。
如使用已有实例,数据库信息将自动填入,您无需重复输入。
如不使用已有实例,您需要输入下方的数据库信息。
数据库类型 选择MySQL。 接入方式 选择云实例。 实例地区 选择目标MyBase MySQL实例所属地域。 RDS实例ID 选择目标MyBase MySQL实例ID。 数据库账号 填入目标MyBase实例的数据库账号,权限要求请参见数据库账号的权限要求。 数据库密码 填入该数据库账号对应的密码。
连接方式 根据数据安全要求选择非加密连接或SSL安全连接,本文以非加密连接为例介绍配置流程。 - 配置完成后,单击测试连接以进行下一步。
- 如果您的自建数据库具备白名单安全设置,您需要复制弹跳框中的DTS服务器IP地址,并加入自建数据库的白名单安全设置中。然后单击测试连接以进行下一步。
说明
- 如果源或目标数据库是阿里云数据库实例(例如MyBase MySQL)或ECS上的自建数据库,DTS会自动将对应地区DTS服务的IP地址添加到阿里云数据库实例的白名单或ECS的安全规则中,您无需手动添加,请参见DTS服务器的IP地址段;如果源或目标数据库是IDC自建数据库或其他云数据库,则需要您手动添加对应地区DTS服务的IP地址,以允许来自DTS服务器的访问。
- 上述场景中,DTS自动添加或您手动添加DTS服务的公网IP地址段可能会存在安全风险,一旦使用本产品代表您已理解和确认其中可能存在的安全风险,并且需要您做好基本的安全防护,包括但不限于加强账号密码强度防范、限制各网段开放的端口号、内部各API使用鉴权方式通信、定期检查并限制不需要的网段,或者使用通过内网(专线/VPN网关/智能网关)的方式接入。
- DTS任务完成或释放后,建议您手动检测并删除DTS相关的服务器IP地址段。
如果您的自建数据库具备白名单安全设置,您需要复制弹跳框中的DTS服务器IP地址,并加入自建数据库的白名单安全设置中。然后单击测试连接。
警告DTS自动添加或您手动添加DTS服务的公网IP地址段可能会存在安全风险,一旦使用本产品代表您已理解和确认其中可能存在的安全风险,并且需要您做好基本的安全防护,包括但不限于加强账号密码强度防范、限制各网段开放的端口号、内部各API使用鉴权方式通信、定期检查并限制不需要的网段,或者通过内网(专线/VPN网关/智能网关)的方式接入。
- 配置任务对象及高级配置。
- 基础配置:在目标库对象名称大小写策略中选择DTS默认策略。数据迁移期间请勿清理源库的增量数据日志,且增量迁移不支持trigger的同步。
配置 说明 任务步骤 如果只需要进行全量迁移,建议同时选中库表结构迁移和全量迁移。
如果需要进行不停机迁移,建议同时选中库表结构迁移、全量迁移和增量迁移。
说明若未选中库表结构迁移,请确保目标库中存在接收数据的数据库和表,并根据实际情况,在已选择对象框中使用库表列名映射功能。
若未选中增量迁移,为保障数据一致性,数据迁移期间请勿在源实例中写入新的数据。
目标已存在表的处理模式 预检查并报错拦截:检查目标数据库中是否有同名的表。如果目标数据库中没有同名的表,则通过该检查项目;如果目标数据库中有同名的表,则在预检查阶段提示错误,数据迁移任务不会被启动。
说明如果目标库中同名的表不方便删除或重命名,您可以更改该表在目标库中的名称,请参见库表列名映射。
忽略报错并继续执行:跳过目标数据库中是否有同名表的检查项。
警告选择为忽略报错并继续执行,可能导致数据不一致,给业务带来风险,例如:
表结构一致的情况下,在目标库遇到与源库主键的值相同的记录:
全量期间,DTS会保留目标集群中的该条记录,即源库中的该条记录不会迁移至目标数据库中。
增量期间,DTS不会保留目标集群中的该条记录,即源库中的该条记录会覆盖至目标数据库中。
表结构不一致的情况下,可能导致只能迁移部分列的数据或迁移失败,请谨慎操作。
同步对象 在源库对象框中单击待迁移的对象,然后单击
将其移动到已选择对象框。 - 高级配置。在配置ETL功能中,选择是否开启ETL功能(默认选择否)。
配置 说明 监控报警 根据业务需求选择是否设置告警并接收告警通知。
不设置:不设置告警。
设置:设置告警。您还需要设置告警阈值和告警联系人,当迁移失败或延迟超过阈值后,系统将进行告警通知。
目标库对象名称大小写策略 您可以配置目标实例中迁移对象的库名、表名和列名的英文大小写策略。默认情况下选择DTS默认策略,您也可以选择与源库、目标库默认策略保持一致。更多信息,请参见目标库对象名称大小写策略。
复制源表Online DDL工具执行过程的临时表到目标库 若源库使用数据管理DMS(Data Management)或gh-ost执行Online DDL变更,您可以选择是否迁移Online DDL变更产生的临时表数据。
重要DTS任务暂不支持使用pt-online-schema-change等类似工具执行Online DDL变更,否则会导致DTS任务失败。
各阶段处理方式如下:由于库表结构迁移与全量迁移阶段不允许执行库或表结构变更的DDL操作,因此不受Online DDL策略控制。
库表结构迁移:不受Online DDL策略控制,会创建相关临时表。
全量迁移:不受Online DDL策略控制,全量迁移对象中将不包括临时表的迁移,凡是表名满足正则表达式(
^_(.+)_(?:gho|new)$或^_(.+)_(?:ghc|del|old)$)的表都会被过滤。增量迁移:受Online DDL策略控制。
是:会迁移Online DDL操作产生的临时表(例如
_表名_gho)的数据变更。否,适配DMS Online DDL与否,适配gh-ost:根据正则表达式规则过滤掉gh-ost等工具产生的临时表(例如
_表名_gho)的数据变更。
是:迁移Online DDL变更产生的临时表数据。
说明Online DDL变更产生的临时表数据过大,可能会导致迁移任务延迟。
否,适配DMS Online DDL:不迁移Online DDL变更产生的临时表数据,只迁移源库使用数据管理DMS(Data Management)执行的原始DDL语句。
说明该方案会导致目标库锁表。
否,适配gh-ost:不迁移Online DDL变更产生的临时表数据,支持自定义过滤规则。DTS将根据正则表达式规则过滤掉gh-ost等工具产生的临时表(例如
_表名_gho)的数据变更。您可以根据需要,修改用于匹配影子表和无用表的默认正则表达式:影子表:
^_(.+)_(?:gho|new)$无用表:
^_(.+)_(?:ghc|del|old)$
说明该方案会导致目标库锁表。
源库、目标库无法连接后的重试时间 在迁移任务启动后,若源库或目标库连接失败则DTS会报错,并会立即进行持续的重试连接,默认重试720分钟,您也可以在取值范围(10~1440分钟)内自定义重试时间,建议设置30分钟以上。如果DTS在设置的时间内重新连接上源、目标库,迁移任务将自动恢复。否则,迁移任务将失败。
说明针对同源或者同目标的多个DTS实例,网络重试时间以后创建任务的设置为准。
由于连接重试期间,DTS将收取任务运行费用,建议您根据业务需要自定义重试时间,或者在源和目标库实例释放后尽快释放DTS实例。
- 基础配置:在目标库对象名称大小写策略中选择DTS默认策略。数据迁移期间请勿清理源库的增量数据日志,且增量迁移不支持trigger的同步。
- 上述配置完成后,单击下一步保存任务并预检查。
说明
- 在迁移任务正式启动之前,会先进行预检查。只有预检查通过后,才能成功启动迁移任务。
- 如果预检查失败,单击具体检查项后的提示图标,查看失败详情。
- 您可以根据提示修复后重新进行预检查。
- 如无需修复告警检测项,您也可以选择确认屏蔽、忽略告警项并重新进行预检查,跳过告警检测项重新进行预检查。
- 预检查通过率显示为100%时,单击下一步购买。
- 在购买页面,选择数据迁移实例的链路规格,详细说明请参见下表。
类别 参数 说明 信息配置 链路规格 DTS为您提供了不同性能的迁移规格,迁移链路规格的不同会影响迁移速率,您可以根据业务场景进行选择,详情请参见数据迁移链路规格说明。
配置完成后,阅读并选中《数据传输(按量付费)服务条款》。
单击购买并启动,并在弹出的确认对话框,单击确定。
您可以在迁移任务列表页面,查看迁移实例的具体进度。
说明若迁移实例不包含增量迁移任务,则迁移实例会自动结束。迁移实例自动结束后,运行状态为已完成。
若迁移实例包含增量迁移任务,则迁移实例不会自动结束,增量迁移任务会持续进行。在增量迁移任务正常运行期间,迁移实例的运行状态为运行中。
后续操作
用于数据迁移的数据库账号拥有读写权限,为保障数据库安全性,请在数据迁移完成后,请删除用于数据迁移的数据库账号。