部署dg备库同步ogg

环境:
RAC1:192.168.56.111 (db版本:12.2.0.1)
RAC2:192.168.56.112 (db版本:12.2.0.1)
DG备库:192.168.56.19 (db版本:12.2.0.1) OGG源库
OGG目标库:192.168.56.166 (db版本:11.2.0.4) OGG目标库

 

goldengate 12.1.2.1.0版本开始之初从datagurad的备库进行同步,抽取进程加入关键参数tranlogoptions minefromactivedg

 

但是涉及到支持ddl的配置和注册抽取进程的步骤只能在dg的主库上执行。 下面是我在dg的主库上安装部署好了goldengte(安装ogg、配置支持ddl,注册抽取进程)后,然后在dg从库上的部署ogg的步骤。

 

 

1.停掉从库的复制进程,并删除dirdat目录下的内容
GGSCI (epidb01) 2> stop repep
epidb01-> cd dirdat
epidb01-> rm ep*

 

2.主库停掉并删除主库的抽取进程
stop extract dpep
stop extract extep
dblogin userid goldengate,password goldengate
delete extract dpep
delete extract extep

 

3.主库创建抽取和投递进程
GGSCI>edit params dpep
GGSCI>ADD EXTRACT dpep, EXTTRAILSOURCE ./dirdat/ep
GGSCI>ADD RMTTRAIL ./dirdat/ep, EXTRACT dpep, MEGABYTES 100
---dpep参数如下:

extract dpep
userid goldengate, password AACAAAAAAAAAAAKAPATACEHBIGQGCFZCCDIGAEMCQFFBZHVC ,ENCRYPTKEY DEFAULT
RmtHost 192.168.56.166, MgrPort 7819, Compress
RmtTrail ./dirdat/ep
gettruncates
Passthru
table hxl.*;

 

4.抽取进程
GGSCI>edit params extep
GGSCI>ADD EXTRACT extep, tranlog, begin now, threads 2 ##注意这里虽然dg是单节点的,但是dg的主库是rac环境的,这里必须写对应的节点数
GGSCI>ADD EXTTRAIL ./dirdat/ep, EXTRACT extep, megabytes 100

---extep参数如下:

extract extep
userid goldengate, password AACAAAAAAAAAAAKAPATACEHBIGQGCFZCCDIGAEMCQFFBZHVC ,ENCRYPTKEY DEFAULT
SETENV (ORACLE_SID="dg12c")
SETENV ( NLS_LANG = AMERICAN_AMERICA.ZHS16GBK)
exttrail ./dirdat/ep
BR BRINTERVAL 20M
numfiles 5000
warnlongtrans 3h, checkinterval 10m
TRANLOGOPTIONS LOGRETENTION ENABLED
--TRANLOGOPTIONS AltArchiveLogDest /u01/app/oracle/archive_log/
tranlogoptions minefromactivedg
--TRANLOGOPTIONS  ASMUSER sys@asmtns_rac01, ASMPASSWORD oracle
--TRANLOGOPTIONS DBLOGREADER

--DDL parameter
DDL &
EXCLUDE INSTR 'shrink space CHECK' &
INCLUDE MAPPED OBJTYPE 'TABLE' &
INCLUDE MAPPED OBJTYPE 'INDEX' &
INCLUDE MAPPED OBJTYPE 'SEQUENCE' &
INCLUDE MAPPED OBJTYPE 'VIEW' &
INCLUDE MAPPED OBJTYPE 'PROCEDURE' &
INCLUDE MAPPED OBJTYPE 'FUNCTION' &
INCLUDE MAPPED OBJTYPE 'PACKAGE' 


--DDLOPTIONS ADDTRANDATA REPORT 

table hxl.tb_ogg_test;

 

6.删除掉主库上./dirdat目录下的ep开头的文件

[oracle@localhost dirdat]$ cd /goldengate12c/dirdat

[oracle@localhost dirdat]$ rm ep*

 

7.启动主库的抽取进程
start extep -- 主库
start dpep -- 主库

 

---------------------------------从库操作-------------------------

1.停掉监听器并杀掉ogg目标库用户下的进程

lsnrctl stop

Select Distinct
                'alter system kill session   ' || '''' || b.sid || ',' ||b.SERIAL# ||  ''';' kill_command,
                b.Username
  From Gv$sql a,
       Gv$session b,
       Gv$session_Wait c,
       Gv$latchholder d,
       Gv$locked_Object e,
       (Select lk.inst_id,Lk.Sid, Lk.Type, Lt.Name Lock_Name
          From Gv$lock      Lk,
               Gv$lock_Type Lt
         Where Lk.Type = Lt.Type
           And lk.inst_id = lt.inst_id
         Group By lk.inst_id,Lk.Sid, Lk.Type, Lt.Name) f,
       (Select Addr,
               inst_id,
               program,
               Sum(Pga_Used_Mem) Pga_Used_Mem,
               Sum(Pga_Alloc_Mem) Pga_Alloc_Mem,
               Sum(Pga_Freeable_Mem) Pga_Freeable_Mem,
               Sum(Pga_Max_Mem) Pga_Max_Mem
          From Gv$process
         Group By Addr,
               inst_id,
               program) g,
       Gv$sort_Usage h
       --Gv$session_Longops Sl
 Where a.Sql_Id = b.Sql_Id
   And b.Sid = c.Sid
   And b.Sid = d.Sid(+)
   And b.Sid = e.Session_Id(+)
   And b.Sid = f.Sid(+)
   And b.Paddr = g.Addr(+)
   And b.Saddr = h.Session_Addr(+)
   --And b.Sid = Sl.Sid(+)
   And b.Status = 'ACTIVE'
   And b.Username In ('ogg目标库业务用户');

 

2.从库停掉并删除复制进程
stop replicat repep
dblogin userid goldengate,password goldengate
delete replicat repep

3.配置从库复制进程

>edit params repep
>add replicat repep, exttrail ./dirdat/ep, NODBCHECKPOINT

 

这里先不启动
--repep参数如下

replicat repep
userid goldengate, password AACAAAAAAAAAAAKAPATACEHBIGQGCFZCCDIGAEMCQFFBZHVC ,ENCRYPTKEY DEFAULT
DiscardFile ./dirrpt/repep.dsc, append, Megabytes 200
gettruncates
AllowNoopUpdates
ASSUMETARGETDEFS
DBOPTIONS SUPPRESSTRIGGERS
DBOPTIONS DEFERREFCONST
HANDLECOLLISIONS
MAP hxl.tb_ogg_test ,TARGET hxl.tb_ogg_test;
DDLERROR 10655 IGNORE
DDLERROR 10636 IGNORE

 

4.数据初始化
a.查询主库SCN:select current_scn from v$database,然后修改/home/oracle/impdblink.sh脚本
将FLASHBACK_SCN替换为查出来的值,我这里通过dblink查询
SQL> set numw 20;
SQL> select current_scn from v$database@dblink_dg备库; ##这里是备库的scn,好像也可以连接主库查scn

CURRENT_SCN
--------------------
75738330810


b.执行impdb脚本(/home/oracle/impdblink.sh)
epidb01-> cd /home/oracle
nohup ./impdblink.sh > impdblink.out 2>&1 &

该脚本内容如下:
epidb01-> more impdblink.sh
#! /bin/bash
impdp goldengate/goldengate network_link=dblink_dg主库 FLASHBACK_SCN=2149986 directory=DATA_PUMP_DIR EXCLUDE=STATISTICS cluster=n tables=hxl.tb_ogg_test parallel=40 table_exists_action=replace

dblink_dg主库 这里是连接主库的dblink,若是连接备库的tns会报如下错误

 

Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
FLASHBACK automatically enabled to preserve database integrity.
Starting "GOLDENGATE"."SYS_IMPORT_TABLE_03":  goldengate/******** network_link=dblink_dg12c FLASHBACK_SCN=2166813 directory=DATA_PUMP_DIR EXCLUDE=STATISTICS cluster=n tables=hxl.tb_ogg_test parallel=40 table_exists_action=replace 
ORA-39126: Worker unexpected fatal error in KUPW$WORKER.MAIN [INSERT INTO SYS.KU$_LIST_FILTER_TEMP_2@dblink_dg12c  (process_order,duplicate,object_schema,object_name,base_process_order,parent_process_order) SELECT process_order,duplicate,object_schema,object_name,base_process_order,parent_process_order FROM "GOLDENGATE"."SYS_IMPORT_TABLE_03" WHERE process_order = :1] 
ORA-08176: consistent read failure; rollback data not available
ORA-02063: preceding line from ORA11G
ORA-02063: preceding 2 lines from DBLINK_DG12C

ORA-06512: at "SYS.DBMS_SYS_ERROR", line 95
ORA-06512: at "SYS.KUPW$WORKER", line 9715

----- PL/SQL Call Stack -----
  object      line  object
  handle    number  name
0xc2a6e0e8     21979  package body SYS.KUPW$WORKER
0xc2a6e0e8      9742  package body SYS.KUPW$WORKER
0xc2a6e0e8      1878  package body SYS.KUPW$WORKER
0xc26cf850         2  anonymous block

Job "GOLDENGATE"."SYS_IMPORT_TABLE_03" stopped due to fatal error at Wed Apr 7 23:34:41 2021 elapsed 0 00:00:01

 

 

 


c.从库启动复制进程
GGSCI>start repep aftercsn 2149986

d.启动从库的监听器
lsnrctl start


备注说明:
1.创建dblink
connect goldengate/goldengate
create public database link dblink_dg备库 connect to goldengate identified by goldengate using 'dg备库TNS';
create public database link dblink_dg主库 connect to goldengate identified by goldengate using 'dg主库TNS';

 

posted @ 2021-04-08 11:14  slnngk  阅读(1336)  评论(2编辑  收藏  举报