正式環境有兩個數據庫A和B,在A庫上建的dblink,業務是要將A庫中的一些表,通過dblink更新到B庫中去,更新的時候總是報錯:ORA-02049: 超時: 分布式事務處理等待超時。
之前我寫過一篇blog:ORA-02049: 超時: 分布式事務處理等待鎖模擬,大致的意思是通過A更新B中的數據時,由於B庫中的數據有鎖,一直都不釋放,導致通過A更新報錯。
診斷如下:
在B庫上執行,找到產生鎖的會話
select s.owner, s.object_name, l.SID, l.TYPE, l.LMODE, l.REQUEST, l.BLOCK
from gv$lock l, dba_objects s
where l.ID1 = s.object_id
and s.object_name = 'TEST';.
再找到有鎖的會話信息,然後通過osuser,machine找到具體應用,停止應用後再進行測試就可以了。
select sid,username,schemaname,osuser,machine,program from gv$session where sid=1142;