故障现象:
抽取进程就
abended
,重启无法启动,报错OGG-00470,如下图
报错可以明显看到错误和DDL操作相关,对于不熟悉的报错,我们可以借助MOS官方文档作为工具。
的确在上面可以查到这个报错相关信息(文档号:
1379867.1)。
该错误是
bug 12989410
引起的,在
ddl
触发器中同一
session
里执行数据库回收站的
ddl
操作引起的内存覆盖导致的:
根据官方文档,使用内部隐含DDLERROR _SKIPDDL <markerSequenceNumber> 可以跳过此错误(文档上另一个方法清空回收站,尝试后并没有解决此问题):

具体步骤如下:
编辑参数文件yt_ext ,将隐含参数加入:
以上参数需要查询<markerSequenceNumber> ,该值是ogg 执行ddl 的标记序号,可以通过查询ddl%20maker%20table 和ogg 的进程report 日志找到相关信息,以下为ogg 的dll 相关对象
通过查询odc.ggs_maker
表中记录,查到好多相关的标记序号,要进一步查询具体的值,进入进程的report
日志查询信息(view report yt_ext
)

在report
日志中可以找出具体的标记序号值,写入参数即可:

查出所有该错误的标记序号写入配置文件后,重启进程,成功跳过错误ddl 标记序号, 通过 ogg 隐含参数,成功绕过了该 bug , ogg 进程恢复正常。
