4.2 入云同步使用须知
4.2.15 Oracle->GaussDB(DWS)
使用技巧(需要人为配合)
推荐提前2-3天启动任务,并配合如下使用技巧和操作要求,以确保任务稳定运行。
● 基于以下原因,建议您结合定时启动功能,选择业务低峰期开始运行同步任务。
– 在网络无瓶颈的情况下,全量同步会对源数据库增加约50MB/s的查询压力,
以及占用2~4个CPU。
– 同步无主键表时,为了确保数据一致性,会存在3s以内的单表级锁定。
– 正在同步的数据被其他事务长时间锁死,可能导致读数据超时。
– DRS并发读取数据库,会占用大约6-10个session连接数,需要考虑该连接数 对业务的影响。
– 全量阶段读取表数据时,特别是大表的读取,可能会阻塞业务上对大表的独 占锁操作。
● 建议您结合数据对比的“稍后启动”功能,选择业务低峰期进行数据对比,以便
● 表等对象名同步到目标库后会转换成小写,如ABC会转换为abc。
因此增量同步阶段,选择的源库的表中不能存在仅大小写不同的 表,可能会导致同步失败。
● 如有中文、日文等特殊字符,业务连接Oracle数据库使用的编码 需和Oracle数据库服务端编码一致,否则目标库可能会出现乱 码。
● 由于无主键表缺乏行的唯一性标志,网络不稳定时涉及少量重 试,表数据存在少量不一致的可能性。
● Oracle中表结构长度(所有列长字节数之和,char、varchar2等 类型字节长度和编码有关)超过65535时,可能导致同步失败。
● 源库为Oracle RAC环境时,如果需要使用scanip,需要保证 scanip与源库的所有vip互通,否则无法通过连接检查。若不使用 scanip,可以使用某一节点的vip,其他节点异常不影响同步。
● 对于Oracle RAC集群,建议使用scanip+ servicename方式创建 任务,scanip具有更强的容错性,更好的负载能力,更快的同步 体验。
● 索引同步只同步普通索引,主键等约束在表结构中进行同步。
● 使用DRS同步表结构的场景下,同一个schema中,同步的表中,
表、约束、索引等不能有忽略大小写后的同名对象,比如表
"A"中有索引名"inx1", 表B中有索引名"a",表A和索引"a"忽略 大小写重名了,会导致结构同步失败。多个schema映射到一个 schema的场景,源库的多个schema中也不能包含同名但字母大 小写不同的表、约束和索引。
● 增量同步时,BLOB末尾的0x00、CLOB末尾的空格会被截断。
● 当Oracle字符集是WE8MSWIN1252时,CLOB列同步到目标库可 能出现乱码,建议先修改源库字符集为AL32UTF8再同步数据。
● 支持源端多张表对GaussDB(DWS)一张表的映射。详细操作可参 考Oracle数据库到GaussDB(DWS)同步实例。
类型名称 操作限制(需要人为配合)
操作须知 ● 同步程中,不允许删除连接源和目标数据库的用户的用户名、密 码、权限,或修改目标数据库的端口号。
● 增量同步过程中,支持部分DDL操作。
– 表级同步支持alter table add column、alter table drop column、alter table modify column以及truncate table的基 本DDL。
● 库级映射和表级映射均不区分大小写,例如映射为abc与映射为 ABC,同步到目标库后均为abc。
● 任务再编辑增加新表时,请确保新增的表的事务都已提交,否则
– 需要具有CREATE SESSION、SELECT ANY TRANSACTION、
SELECT ANY TABLE、SELECT ANY DICTIONARY权限和 EXECUTE_CATALOG_ROLE角色,若Oracle为12C及以上版本 还需要LOGMINING权限。
– 12c 以上版本 PDB 数据库同步时,需要为用户赋予如下权 限:在CDB下创建C##前缀的容器数据库用户赋予CREATE SESSION、SELECT ANY DICTIONARY、SELECT ANY
TABLE、LOGMINING、EXECUTE_CATALOG_ROLE权限和SET CONTAINER权限(GRANT SET CONTAINER TO
C##USERNAME CONTAINER= ALL;)。
在PDB下为C##前缀用户赋予以下权限(其中RESTRICTED SESSION、SELECT ON SYS.COL$、 SELECT ON SYS.OBJ$权 限需要单独赋予):RESTRICTED SESSION、CREATE SESSION、SELECT ANY DICTIONARY、
EXECUTE_CATALOG_ROLE、SELECT ANY TRANSACTION、
SELECT ANY TABLE、LOGMINING、SELECT ON SYS.COL
$、SELECT ON SYS.OBJ$。
● 目标数据库帐号必须具有每张表的如下权限:INSERT、
SELECT、UPDATE、DELETE、CONNECT、CREATE、
REFERENCES。
类型名称 使用限制(DRS自动检查)
同步对象约
束 ● 支持表、索引、约束(主键、空、非空)的同步,不支持视图、
外键、存储过程、触发器、函数、事件、虚拟列的同步。
● 不支持的数据类型有:xml、geometry、point、lineString、
polygon、geometrycollection、multipoint、multilinestring、
multipolygon。
● 对于TIMESTAMP WITH TIME ZONE类型,根据目标库时区做转 换后不得大于“9999-12-31 23:59:59.999999”。
● 源库支持to_date和sys_guid函数做默认值。将函数作为default值 时,需要目标库也有相同功能的函数。对于目标库不存在对应函