GoldenGate进程失败后怎么跳过当前事务
发布网友
发布时间:2022-04-21 16:08
我来回答
共2个回答
热心网友
时间:2022-05-05 00:25
1,定位REPLICAT进程当前事务所在列队文件及RBA:
GGSCI (sv890n01) 46> info rads_1
REPLICAT RADS_1 Last Started 2012-12-08 16:29 Status ABENDED
Checkpoint Lag 02:23:36 (updated 00:01:38 ago)
Log Read Checkpoint File ./dirdat/pa000002
2012-12-08 14:05:51.970013 RBA 77698825
2,由于在列队中相邻两个事务的 RBA 并不是简单的 +1 关系,所以下一步需要定位到下个事务的RBA,在这里需要借助 logmp 工具。
打开列队文件:
Logmp 10 >open ./dirdat/pa000002
Current LogTrail is /u01/app/oracle/oradata/ogg/dirdat/pa000002
定位到指定的RBA位置:
Logmp 11 >pos 77698825
Reading forward from RBA 77698825
查看当前事务详细信息,在这里可以看到DDL/DML操作类型,RBA,对象名等一些相关信息:
Logmp 12 >n
2012/12/08 14:05:52.970.013 DDLOP Len 1221 RBA 77698825
Name:
After Image: Partition 0 G s
2c43 353d 2735 3730 3727 2c2c 4237 3d27 3537 3037 | ,C5='5707',,B7='5707
272c 2c42 323d 2735 3631 3330 3027 2c2c 4233 3d27 | ',,B2='561300',,B3='
4f47 4727 2c2c 4234 3d27 4442 4d53 5f54 4142 434f | OGG',,B4='DBMS_TABCO
4d50 5f54 454d 505f 554e 434d 5027 2c2c 4331 323d | MP_TEMP_UNCMP',,C12=
2727 2c2c 4331 333d 2727 2c2c 4235 3d27 5441 424c | '',,C13='',,B5='TABL
4527 2c2c 4236 3d27 4452 4f50 272c 2c42 383d 274f | E',,B6='DROP',,B8='O
4747 2e47 4753 5f44 444c 5f48 4953 5427 2c2c 4239 | GG.GGS_DDL_HIST',,B9
查看下一个事务信息:
Logmp 13 >n
2012/12/08 14:05:52.970.013 Insert Len 370 RBA 77700210
Name: DATAGATE.TB_DOWNLOAD_LOG
After Image: Partition 4 G s
0000 0009 0000 0005 7274 7231 3100 0100 0900 0000 | ........rtr11.......
0531 3036 3034 0002 001d 0000 0019 5943 3159 3037 | .10604........YC1Y07
315f 3132 3939 3537 3833 3534 3932 342e 786d 6c00 | 1_1299578354924.xml.
0300 0300 0030 0004 00bf 0000 00bb 6874 7470 3a2f | .....0........http:/
2f64 6174 6167 6174 652e 6368 696e 6162 6f6e 642e | /datagate.chinabond.
636f 6d2e 636e 2f64 6174 6167 6174 652f 6469 7370 | com.cn/datagate/disp
6174 6368 3f66 756e 635f 6964 3d32 3031 3126 7374 | atch?func_id=2011&st
至此已经定位到下一个事务的RBA。
3,在GGSCI中通过重新指定REPLICAT进程的当前RBA以跳过当前事务
GGSCI (sv890n01) 47> alter replicat rads_1,extrba 77700210
REPLICAT altered.
GGSCI (sv890n01) 48> start rads_1
Sending START request to MANAGER ...
REPLICAT RADS_1 starting