GoldenGate复制单表开并行
admin
2023-05-25 05:40:02
0

最近有几项业务下线,需要从一张表中删除6.8亿多条数据。想办法把数据删除掉了,但对应的ogg灾备端复制时有了的延迟,而且延迟的时间起来越长。

对于表太多造成的延迟可以把所有表分为多个组来做复制,于是想复制进程是否可以对单表复制开并行。上网查到了相关的资料,可以使用@RANGE函数对单表作表内的拆分,通过对表上主键列作hash算法将该表上发生的变更均分到多个replicat上来降低单个replicat组件的负载。

动手实验一下:

ogg搭建过程不再重复,从网上就可以查到。

实验过程:模拟在源端对表scott.emp1做大量的dml操作,复制进程出现延迟,在目标端对复制表scott.emp1开并行3个进程。

源端插入数据:

SQL> insert into scott.emp1 select * from scott.emp;

14 rows created.

SQL> commit;

Commit complete.

SQL> insert into scott.emp1 select * from scott.emp1;

14 rows created.

SQL> /

28 rows created.

SQL> /

.......

SQL> /

1835008 rows created.

SQL> commit;

Commit complete.

SQL> select count(*) from scott.emp1;

  COUNT(*)
----------
   3670016

目标端有延迟

GGSCI (rhel5) 15> info all

Program     Status      Group       Lag           Time Since Chkpt

MANAGER     RUNNING                                           
REPLICAT    RUNNING     REPTAB      00:09:08      00:00:04

停掉复制进程

拆分复制进程,对表scott.emp1分三个进程复制

#源复制进程

GGSCI (rhel5) 23> view params reptab

replicat reptab
SETENV (NLS_LANG="AMERICAN_AMERICA.ZHS16GBK")
SETENV (ORACLE_SID="orcl")
userid ogg,password 123456
reperror default,discard
assumetargetdefs
discardfile /goldengate/dirrpt/reptab.dsc,append,megabytes 1024
gettruncates
dynamicresolution
map scott.emp1, target scott.emp1 ;
map scott.emp, target scott.emp ;

源进程修改为

map scott.emp1, target scott.emp1 ,FILTER(@RANGE(1,3));

多复制出两个参数文件:

GGSCI (rhel5) 1> view params reptab02

replicat reptab02
SETENV (NLS_LANG="AMERICAN_AMERICA.ZHS16GBK")
SETENV (ORACLE_SID="orcl")
userid ogg,password 123456
reperror default,discard
assumetargetdefs
discardfile /goldengate/dirrpt/reptab.dsc,append,megabytes 1024
gettruncates
dynamicresolution
map scott.emp1, target scott.emp1 ,FILTER (@RANGE(2,3));


GGSCI (rhel5) 2> view params reptab03

replicat reptab03
SETENV (NLS_LANG="AMERICAN_AMERICA.ZHS16GBK")
SETENV (ORACLE_SID="orcl")
userid ogg,password 123456
reperror default,discard
assumetargetdefs
discardfile /goldengate/dirrpt/reptab.dsc,append,megabytes 1024
gettruncates
dynamicresolution
map scott.emp1, target scott.emp1 ,FILTER (@RANGE(3,3));

添加两个复制进程,extseqno和extrba与源进程一致

GGSCI (rhel5) 9> info reptab

REPLICAT   REPTAB    Last Started 2017-05-05 16:18   Status ABENDED
Checkpoint Lag       00:09:08 (updated 00:09:38 ago)
Log Read Checkpoint  File ./dirdat/tl000003
                     2017-05-05 16:09:11.000187  RBA 194186157
                     
GGSCI (rhel5) 10> add replicat reptab02, exttrail ./dirdat/tl,extseqno 3 extrba 194186157,checkpointtable ogg.checkpoint
REPLICAT added.


GGSCI (rhel5) 11> add replicat reptab03, exttrail ./dirdat/tl,extseqno 3 extrba 194186157,checkpointtable ogg.checkpoint
REPLICAT added.

启动复制进程

GGSCI (rhel5) 12> start reptab*

Sending START request to MANAGER ...
REPLICAT REPTAB starting

Sending START request to MANAGER ...
REPLICAT REPTAB02 starting

Sending START request to MANAGER ...
REPLICAT REPTAB03 starting

查看数据库里ogg对应的会话

SQL> select module,sql_id from v$session where username='OGG';

MODULE																		 SQL_ID
------------------------------------------------------------------------------------------------------------------------------------------------ ---------------------------------------
OGG-REPTAB03-OPEN_DATA_SOURCE															 1cxrusnmn01hz
OGG-REPTAB-OPEN_DATA_SOURCE                                                                                                                      1cxrusnmn01hz
OGG-REPTAB02-OPEN_DATA_SOURCE															 1cxrusnmn01hz

SQL> select sql_text from v$sqlarea where sql_id='1cxrusnmn01hz';

SQL_TEXT
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
INSERT INTO "SCOTT"."EMP1" ("EMPNO","ENAME","JOB","MGR","HIREDATE","SAL","COMM","DEPTNO") VALUES (:a0,:a1,:a2,:a3,:a4,:a5,:a6,:a7)

可以看到出现了三个会话,都是对应的对表scott.emp1的插入语句。也就是说实现了对scott.emp1表的并行复制。


MOS上也有相关的文档介绍相应的功能,文档:1320133.1和1512633.1

参考:blog.itpub.net/15187685/viewspace-1219731/


相关内容

热门资讯

美国被曝将于20日起诉劳尔·卡... 在对古巴进行了长达数月的极限施压后,美国正酝酿下一步行动。美国被曝将于5月20日正式起诉古巴前领导人...
身家320亿元,超级富豪离奇坠... 据西班牙国家警察总署最新消息,西班牙服装巨头Mango创始人伊萨克•安迪奇(Isak Andic)之...
请问一下台式电脑怎么看配置参数 想要查看台式电脑的参数情况其实非常简单,就是在您的电脑上面装一个鲁大师,然后在鲁大师当中选择检测,那...
求问笔记本电脑键盘错乱了怎么调... 最佳回答在笔记本电脑的键盘出现了错乱的问题之后,现在想要把它调整回来,则需要通过如下的方式去尝试。第...
求问笔记本电脑怎么设置锁屏密码 最佳回答笔记本电脑设置屏锁密码的做法是可按照如下的8个步骤来完成的。第1个步骤是先打开自己的电脑wi...
怎么看笔记本电脑配置 如何看笔... 鼠标右键点击【计算机】,选择【属性】点击打开,在弹出窗口中可以看到CPU和内存的配置信息,然后点击【...
电线接线端子的弊端 电线在很多地方都会用到,然而在接电线的时候却可以选择各种各样的方式,那么您如果在接线的时候选择了接线...
广东中山启动防汛Ⅲ级应急响应,... 总台记者从广东省中山市三防指挥部获悉,目前,中山市三角镇3小时雨量已达100毫米,预计强降雨仍将持续...
《给阿嬷的情书》收获高口碑,国... 【环球时报特约记者 董铭】一部小成本潮汕方言电影成了卖座片,这出乎很多人意料。截至5月19日中午12...
“585人村庄62人患癌”追踪... 近日,据大象新闻报道,武汉市新洲区一个585人的村庄有62人先后患癌和白血病,村民们怀疑此事与村里一...