本文介绍如何使用数据传输服务DTS(Data Transmission Service),将自建MySQL迁移至RDS MySQL实例。DTS支持结构迁移、全量数据迁移以及增量数据迁移,同时使用这三种迁移类型可以实现在自建应用不停服的情况下,平滑地完成自建MySQL数据库的迁移上云。
支持的源和目标数据库
MySQL间迁移支持以下源或目标数据库。本文以有公网IP的自建数据库为源数据库,RDS MySQL实例为目标数据库介绍配置流程,其他数据源配置流程与本案例类似。源数据库 | 目标数据库 |
---|---|
|
|
前提条件
- 自建MySQL数据库版本为5.1、5.5、5.6、5.7或8.0版本。
- 如果您的MySQL数据库部署在本地,那么您需要将DTS服务器的IP地址设置为该数据库远程连接的白名单,允许其访问您的数据库。详情请参见迁移、同步或订阅本地数据库时需添加的IP白名单。
- 已创建目标RDS MySQL实例,创建方式,请参见创建RDS MySQL实例。
- RDS MySQL实例的存储空间须大于自建MySQL数据库占用的存储空间。
注意事项
类型 | 说明 |
---|---|
源库限制 |
|
其他限制 |
|
特殊情况 |
|
费用说明
迁移类型 | 链路配置费用 | 公网流量费用 |
---|---|---|
结构迁移和全量数据迁移 | 不收费。 | 通过公网将数据迁移出阿里云时将收费,详情请参见计费概述。 |
增量数据迁移 | 收费,详情请参见计费概述。 |
迁移类型说明
- 库表结构迁移
DTS将源库中迁移对象的结构定义迁移到目标库。
说明- 目前DTS支持结构迁移的对象为表、视图、触发器、存储过程和存储函数。
- 在结构迁移时,DTS会将视图、存储过程和函数中的DEFINER转换为INVOKER。
- 由于DTS不迁移USER信息,因此在调用目标库的视图、存储过程和函数时,需要对调用者授予读写权限。
- 全量迁移
DTS将源库中迁移对象的存量数据,全部迁移到目标库中。
- 增量迁移
DTS在全量迁移的基础上,将源库的增量更新数据迁移到目标库中。通过增量数据迁移可以实现在自建应用不停机的情况下,平滑地完成数据迁移。
支持增量迁移的SQL操作
操作类型 | SQL操作语句 |
---|---|
DML | INSERT、UPDATE、DELETE |
DDL |
|
数据库账号的权限要求
数据库 | 库表结构迁移 | 全量迁移 | 增量迁移 |
---|---|---|---|
自建MySQL数据库 | SELECT权限 | SELECT权限 | 增量数据迁移:待迁移对象的SELECT权限
REPLICATION CLIENT、REPLICATION SLAVE、SHOW VIEW 建库建表的权限,以允许DTS创建库dts,用于记录迁移期间的心跳数据 |
RDS MySQL实例 | 读写权限 |
数据库账号创建及授权方法:
- 自建MySQL数据库请参见为自建MySQL创建账号并设置binlog。
- RDS MySQL实例请参见创建账号和修改账号权限。