数据传输服务DTS(Data Transmission Service)支持将RDS SQL Server同步至RDS MySQL。
前提条件
- 已创建源RDS SQL Server实例,支持的版本,请参见同步方案概览。创建方式,请参见创建RDS SQL Server实例。
注意 目前支持源RDS SQL Server版本为2012、2014、2016、2017或2019版本。
- 已创建目标RDS MySQL实例,创建方式,请参见创建RDS MySQL实例。
- RDS MySQL实例的存储空间须大于RDS SQL Server实例占用的存储空间。
- 若源端存在如下情况,建议使用RDS SQL Server数据库的备份功能进行同步,详情请参见从自建数据库迁移至RDS。
- 源库实例数超过10个。
- 源库实例执行日志备份操作的频率超过1次/小时。
- 源库实例执行DDL操作的频率超过100条/小时。
- SQL Server单库日志量超过20MB/s。
- 需要开启CDC(Change Data Capture,变更数据捕获)的表超过1000个。
- 源库日志存在源端堆表、无主键表、压缩表、含计算列表等场景。可以执行如下SQL检查源库是否存在这些场景的表:
- 检查源库堆表信息:
select s.name as schema_name, t.name as table_name from sys.schemas s inner join sys.tables t on s.schema_id = t.schema_id where t.type = 'U' and t.object_id in (select object_id from sys.indexes where index_id = 0);
- 检查无主键表信息:
select s.name as schema_name, t.name as table_name from sys.schemas s inner join sys.tables t on s.schema_id = t.schema_id where t.type = 'U' and t.object_id not in (select parent_object_id from sys.objects where type = 'PK');
- 检查源库聚集索引列不包含主键列信息:
select object_name(pk_columns.object_id) as table_name from (select sic.object_id object_id, sic.column_id from sys.index_columns sic, sys.indexes sis where sic.object_id = sis.object_id and sic.index_id = sis.index_id and sis.is_primary_key = 'true') pk_columns left join (select sic.object_id object_id, sic.column_id from sys.index_columns sic, sys.indexes sis where sic.object_id = sis.object_id and sic.index_id = sis.index_id and sis.index_id = 1) cluster_colums on pk_columns.object_id = cluster_colums.object_id and cluster_colums.object_id is null;
- 检查源库压缩表信息:
select s.name as schema_name, t.name as table_name from sys.objects t, sys.schemas s, sys.partitions i where s.schema_id=t.schema_id and t.type = 'U' and t.object_id = i.object_id and i.data_compression != 0;
- 检查包含计算列表信息:
select s.name as schema_name, t.name as table_name from sys.schemas s inner join sys.tables t on s.schema_id = t.schema_id where t.type = 'U' and t.object_id in (select object_id from sys.columns where is_computed = 1);
- 检查源库堆表信息:
注意事项
说明 DTS默认同步到目标数据库中时会取消外键约束,因此源数据库的级联、删除等操作不会同步到目标数据库。
类型 | 说明 |
---|---|
源库限制 |
|
其他限制 |
|
支持的同步架构
- 一对一单向同步
- 一对多单向同步
- 多对一单向同步
支持同步的SQL操作
操作类型 | SQL操作语句 |
---|---|
DML | INSERT、UPDATE、DELETE |
DDL |
|