前言
今天在测试 OGG 一个功能的时候,需要重新初始化 oggca,所以重装了一下 OGG。重建完之后重新添加抽取进程报错,一直无法添加成功:

经过一翻分析,找到了解决方案,本文记录一下解决过程。
问题描述
OGG 重装之前,没有清理原先抽取进程,重装后,抽取进程重建失败!
原因是因为添加抽取进程时,会在数据库中的一些表里创建一些数据,用来记录抽取进程的信息。
- dba_capture:displays information about all capture processes in the database.
- dba_apply:displays information about all apply processes in the database.
- system.logmnr_*
如果重建同名进程时未清理对应的记录,会导致无法成功创建抽取进程。
问题解决
经过在 MOS 查找对应的解决方案,最终解决问题。
参考 MOS 文档:Unable To Register OGG Extract (Doc ID 2861271.1)

根据 MOS 提供的清理步骤:
SQL> select session# from system.logmnr_session$ where session_name like '%E_MYSQL%';
-- 执行清理
SQL> delete from system.logmnr_spill$ where session# = 1;
delete from system.logmnr_age_spill$ where session# = 1;
delete from system.logmnr_log$ where session# = 1;
delete from system.logmnr_restart_ckpt$ where session# = 1;
delete from system.logmnr_restart_ckpt_txinfo$ where session# = 1;
delete from system.logmnr_filter$ where session# = 1;
delete from system.logmnr_parameter$ where session# = 1;
delete from system.logmnr_global$ where session# = 1;
delete from system.logmnr_session$ where session# = 1;
commit;
清理后再次添加抽取进程,依然报错。
参考 MOS 文档:Add Extract on GGMA Fails By OGG-08241 (Doc ID 2936927.1)

根据 MOS 提供的清理步骤:
SQL> select capture_name from dba_capture where capture_name like '%E_MYSQL%';
CAPTURE_NAME
----------------------------------------------------------------------------------------------------
OGG$CAP_E_MYSQL
SQL> exec dbms_capture_adm.stop_capture('OGG$CAP_E_MYSQL');
SQL> exec dbms_capture_adm.drop_capture('OGG$CAP_E_MYSQL');
SQL> select apply_name from dba_apply where apply_name like '%E_MYSQL%';
APPLY_NAME
----------------------------------------------------------------------------------------------------
OGG$E_MYSQL
SQL> exec dbms_apply_adm.stop_apply('OGG$E_MYSQL');
SQL> exec dbms_apply_adm.drop_apply('OGG$E_MYSQL');
再次添加抽取进程:



创建成功。问题解决!
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




