程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> ORA-02049:超時:分布式事務處理等待鎖診斷

ORA-02049:超時:分布式事務處理等待鎖診斷

編輯:Oracle教程

ORA-02049:超時:分布式事務處理等待鎖診斷


正式環境有兩個數據庫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;

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved