本文介绍如何使用数据传输服务(Data Transmission Service,简称DTS),将RDS PPAS迁移至PolarDB-O集群。DTS支持结构迁移、全量数据迁移以及增量数据迁移,同时使用这三种迁移类型可以实现在自建应用不停服的情况下,平滑地完成数据库的迁移。
前提条件
- 已创建PolarDB-O集群,详情请参见创建PolarDB-O集群。
- PolarDB-O集群的存储空间须大于RDS PPAS数据库占用的存储空间。
- 如需执行增量数据迁移,您需要提交工单,为源RDS PPAS实例用于数据迁移的账号开通superuser权限。
注意事项
- DTS在执行全量数据迁移时将占用源库和目标库一定的读写资源,可能会导致数据库的负载上升,在数据库性能较差、规格较低或业务量较大的情况下(例如源库有大量慢SQL、存在无主键表或目标库存在死锁等),可能会加重数据库压力,甚至导致数据库服务不可用。因此您需要在执行数据迁移前评估源库和目标库的性能,同时建议您在业务低峰期执行数据迁移(例如源库和目标库的CPU负载在30%以下)。
- 如果源库中待迁移的表没有主键或唯一约束,且所有字段没有唯一性,可能会导致目标数据库中出现重复数据。
- 一个数据迁移任务只能对一个数据库进行数据迁移,如果有多个数据库需要迁移,则需要为每个数据库创建数据迁移任务。
- 对于迁移失败的任务,DTS会触发自动恢复。当您需要将业务切换至目标实例,请务必先终止或释放该任务,避免该任务被自动恢复后,导致源端数据覆盖目标实例的数据。
- 由于业务切换到目标端后,新写入的Sequence不会按照源库的Sequence最大值作为初始值去递增,您需要在业务切换前,在源库中查询对应Sequence的最大值,然后在目标库中将其作为对应Sequence的初始值。查询源库Sequence值的相关命令如下:
do language plpgsql $$ declare nsp name; rel name; val int8; begin for nsp,rel in select nspname,relname from pg_class t2 , pg_namespace t3 where t2.relnamespace=t3.oid and t2.relkind='S' loop execute format($_$select last_value from %I.%I$_$, nsp, rel) into val; raise notice '%', format($_$select setval('%I.%I'::regclass, %s);$_$, nsp, rel, val+1); end loop; end; $$;
迁移类型说明
迁移类型 | 说明 |
---|---|
结构迁移 | DTS将迁移对象的结构定义迁移到目标PolarDB集群。目前支持的对象包括:表、视图、同义词、触发器(不兼容)、存储过程、存储函数、包、自定义类型。
注意 不兼容触发器。当迁移对象包含了触发器可能导致数据不一致。
|
全量数据迁移 | DTS会将源库中迁移对象的存量数据,全部迁移至目标PolarDB集群。
注意 在结构迁移和全量数据迁移完成之前,请勿对迁移对象执行DDL操作,否则可能导致迁移失败。
|
增量数据迁移 | DTS在全量数据迁移的基础上轮询并捕获源库产生的Redo Log,将源库的增量更新实时迁移到目标PolarDB集群。目前支持仅支持同步DML操作(INSERT、UPDATE、DELETE),暂不支持同步DDL操作。
通过增量数据迁移可以实现在应用不停服的情况下,平滑地完成数据迁移。 |
费用说明
迁移类型 | 链路配置费用 | 公网流量费用 |
---|---|---|
结构迁移和全量数据迁移 | 不收费。 | 通过公网将数据迁移出阿里云时将收费,详情请参见产品定价。 |
增量数据迁移 | 收费,详情请参见产品定价。 |
数据库账号的权限要求
登录待迁移的Oracle数据库,创建用于采集数据的账号并授权。
数据库 | 结构迁移 | 全量迁移 | 增量迁移 |
---|---|---|---|
RDS PPAS | 读权限 | 读权限 | superuser权限 |
PolarDB-O集群 | schema的owner权限 | schema的owner权限 | schema的owner权限 |
数据库账号创建及授权方法:
在文档使用中是否遇到以下问题
更多建议
匿名提交