开完早会,来自于开发的一个反馈,说某个时间点业务库有感知异常

add trandata带来的library cache lock_ogg

根据dba_hist_active_sess_history视图查看当时有严重的library cache lock

add trandata带来的library cache lock_ogg_02

在当时时间段,排除了其他业务sql带来的影响,有一个alter table的操作是ogg为source

add trandata带来的library cache lock_加锁_03

add trandata带来的library cache lock_add trandata_04

由于无法使用10046进行追踪,但是我们知道add trandata后面的动作大致是什么,大致就是要lock table,并且alter table add supplemental操作的。一般是三个步骤,有两个步骤是nowait的方式加锁,但是此时该表比较热的话,有一个步骤会带来ORA-00054 resource busy的报错。

结合ogg log,我们互相印证一下相关时间点

add trandata带来的library cache lock_加锁_05


好记性比如烂笔头,一个故障一个思路。