本文介绍如何使用数据传输服务DTS(Data Transmission Service),实现RDS PostgreSQL间的结构迁移、全量数据迁移以及增量数据迁移。同时使用这三种迁移类型可以实现在业务不停服的情况下,平滑地完成数据库的迁移。
前提条件
- 已创建源和目标RDS PostgreSQL实例,详情请参见创建RDS PostgreSQL实例。
说明 建议源和目标数据库的版本相同,或者从低版本迁移到高版本以保障兼容性。
如为高版本迁移至低版本,可能存在数据库兼容性问题。
- 目标RDS PostgreSQL实例的存储空间须大于源RDS PostgreSQL实例占用的存储空间。
注意事项
类型 | 说明 |
---|---|
源库限制 |
|
其他限制 |
|
特殊情况 |
当源实例为RDS PostgreSQL时,迁移期间,请勿修改RDS PostgreSQL的连接地址和可用区,否则会导致迁移失败。 |
迁移类型说明
- 库表结构迁移
DTS将源库中迁移对象的结构定义迁移到目标库。
- 全量迁移
DTS将源库中迁移对象的存量数据,全部迁移到目标库中。
- 增量迁移
DTS在全量迁移的基础上,将源库的增量更新数据迁移到目标库中。通过增量数据迁移可以实现在自建应用不停服的情况下,平滑地完成数据迁移。
支持增量迁移的SQL操作
操作类型 | SQL操作语句 |
---|---|
DML | INSERT、UPDATE、DELETE |
DDL |
|
数据库账号的权限要求
数据库 | 库表结构迁移 | 全量迁移 | 增量迁移 |
---|---|---|---|
源RDS PostgreSQL实例 | pg_catalog的USAGE权限。 | 迁移对象的SELECT权限。 | 高权限账号。
说明 当源实例为RDS PostgreSQL 9.4,且仅需增量迁移DML操作时,账号具备REPLICATION权限即可。
|
目标RDS PostgreSQL实例 | 目标迁移对象的CREATE、USAGE权限。 | Schema的owner权限。 |
RDS PostgreSQL数据库账号创建及授权方法,请参见创建账号。