本文介绍如何使用数据传输服务(Data Transmission Service,简称DTS),将RDS PPAS迁移至PolarDB O引擎集群。DTS支持结构迁移、全量数据迁移以及增量数据迁移,同时使用这三种迁移类型可以实现在自建应用不停服的情况下,平滑地完成数据库的迁移。
前提条件
说明 建议参考从RDS PPAS迁移至PolarDB O引擎集群,使用新版控制台进行操作。
注意事项
- 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; $$;
- RDS PPAS迁移至PolarDB O集群时,建议如下:
- PolarDB O集群的规格大于或等于RDS PPAS规格,避免迁移后因PolarDB O的CPU和内存不足,导致慢SQL或内存溢出。推荐的PolarDB O规格,请参见RDS PPAS与推荐PoalrDB O规格对照表。
- 如果对迁移后的连接数、IOPS等有业务要求,请参考PolarDB O规格列表,选择符合业务需求的PolarDB O规格。
- 应用连接时使用集群地址,可实现自动读写分离,将读请求流量分配到只读节点,降低PolarDB O实例负载。如何获取集群地址,请参见查看或申请连接地址。
RDS PPAS与推荐PoalrDB O规格对照表
建议PolarDB O集群的规格大于或等于RDS PPAS规格,避免迁移后因PolarDB O的CPU和内存不足,导致慢SQL或内存溢出。推荐的PolarDB O规格如下:
RDS PPAS规格 | 推荐的PolarDB O规格 | ||
---|---|---|---|
规格代码 | CPU和内存 | 规格代码 | CPU和内存 |
rds.ppas.t1.small | 1核 1GB | polar.o.x4.medium | 2核 8GB |
ppas.x4.small.2 | 1核 4GB | polar.o.x4.medium | 2核 8GB |
ppas.x4.medium.2 | 2核 8GB | polar.o.x4.medium | 2核 8GB |
ppas.x8.medium.2 | 2核 16GB | polar.o.x4.large | 4核 16GB |
ppas.x4.large.2 | 4核 16GB | polar.o.x4.large | 4核 16GB |
ppas.x8.large.2 | 4核 32GB | polar.o.x4.xlarge | 8核 32GB |
ppas.x4.xlarge.2 | 8核 32GB | polar.o.x4.xlarge | 8核 32GB |
ppas.x8.xlarge.2 | 8核 64GB | polar.o.x8.xlarge | 8核 64GB |
ppas.x4.2xlarge.2 | 16核 64GB | polar.o.x8.2xlarge | 16核 128GB |
ppas.x8.2xlarge.2 | 16核 128GB | polar.o.x8.2xlarge | 16核 128GB |
ppas.x4.4xlarge.2 | 32核 128GB | polar.o.x8.4xlarge | 32核 256GB |
ppas.x8.4xlarge.2 | 32核 256GB | polar.o.x8.4xlarge | 32核 256GB |
rds.ppas.st.h43 | 60核 470GB | polar.o.x8.8xlarge | 64核 512GB |
迁移类型说明
迁移类型 | 说明 |
---|---|
结构迁移 | 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权限 |
数据库账号创建及授权方法: