本文介绍如何使用数据传输服务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地址设置为该数据库远程连接的白名单,允许其访问您的数据库。详情请参见迁移、同步或订阅本地数据库时需添加的IP白名单。
支持的源和目标数据库
MySQL间迁移支持以下源或目标数据库。本文以ECS自建数据库为源数据库,MyBase MySQL实例为目标数据库介绍配置流程,其他数据源配置流程与本案例类似。源数据库 | 目标数据库 |
---|---|
|
|
注意事项
类型 | 说明 |
---|---|
源库限制 |
|
其他限制 |
|
特殊情况 |
|
费用说明
迁移类型 | 链路配置费用 | 公网流量费用 |
---|---|---|
结构迁移和全量数据迁移 | 不收费。 | 通过公网将数据迁移出阿里云时将收费,详情请参见产品定价。 |
增量数据迁移 | 收费,详情请参见产品定价。 |
迁移类型说明
- 库表结构迁移
DTS将源库中迁移对象的结构定义迁移到目标库。
说明- 目前DTS支持结构迁移的对象为表、视图、触发器、存储过程和存储函数。
- 在结构迁移时,DTS会将视图、存储过程和函数中的DEFINER转换为INVOKER。
- 由于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实例请参见创建数据库账号和变更数据库账号。
操作步骤
后续操作
用于数据迁移的数据库账号拥有读写权限,为保障数据库安全性,请在数据迁移完成后,请删除用于数据迁移的数据库账号。