溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Oracle數(shù)據(jù)庫分布式事務(wù)ORA-01591錯誤的解決方法

發(fā)布時間:2021-11-29 15:26:03 來源:億速云 閱讀:427 作者:柒染 欄目:數(shù)據(jù)庫

這篇文章將為大家詳細(xì)講解有關(guān)Oracle數(shù)據(jù)庫分布式事務(wù)ORA-01591錯誤的解決方法,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

最近在update某張表時突然提示了個比較少見的錯誤,ORA-01591,這個問題跟平時的鎖還有點(diǎn)不一樣,下面一起來看看吧~

Oracle數(shù)據(jù)庫分布式事務(wù)ORA-01591錯誤的解決方法

思路

這個錯誤是由于分布式事務(wù)引起,而不是普通的鎖引起的,檢查一般對象數(shù)據(jù)表鎖定,只需要檢查v$locked_object和v$transaction視圖,就可以定位到具體的SQL語句和操作人等信息。

select * from gv$locked_object; select * from gv$transaction;

使用oerr工具查看該錯誤編號

oerr ora 1591 01591, 00000, "lock held by in-doubt distributed transaction %s" // *Cause: Trying to access resource that is locked by a dead two-phase commit // transaction that is in prepared state. // *Action: DBA should query the pending_trans$ and related tables, and attempt // to repair network connection(s) to coordinator and commit point. // If timely repair is not possible, DBA should contact DBA at commit // point if known or end user for correct outcome, or use heuristic // default if given to issue a heuristic commit or abort command to // finalize the local portion of the distributed transaction.

簡單的說,01591錯誤的原因是該對象被一個處在“in-doubt”狀態(tài)的分布式事務(wù)鎖定。分布式事務(wù)使用的是“two-phase  commit”二階段提交技術(shù)。解決該問題的方法就是查看內(nèi)部表pending_trans$,確定分布式事務(wù)信息。這種狀態(tài)的事務(wù)主要是由于在進(jìn)行分布式事務(wù)時候,發(fā)生網(wǎng)絡(luò)突發(fā)中斷的情況,引起分布式事務(wù)無法正常結(jié)束,等待中斷節(jié)點(diǎn)的事務(wù)響應(yīng)。于是,各節(jié)點(diǎn)的事務(wù)所鎖定的表就不會被釋放掉。

處理方法

rollback force '20.13.14721';

Rollback force的參數(shù)是DBA_2PC_PENDING中記錄本地事務(wù)信息的編號即LOCAL_TRAN_ID。

處理還是比較簡單的,這里順便分享下分布式事務(wù)的相關(guān)知識點(diǎn)。

分布式事務(wù)相關(guān)知識點(diǎn)

分布式事務(wù),簡單來說,是指一個事務(wù)在本地和遠(yuǎn)程執(zhí)行,本地需要等待確認(rèn)遠(yuǎn)程的事務(wù)結(jié)束后,進(jìn)行下一步本地的操作。如通過dblink  update遠(yuǎn)程數(shù)據(jù)庫的一行記錄,如果在執(zhí)行過程中網(wǎng)絡(luò)異常,或者其他事件導(dǎo)致本地數(shù)據(jù)庫無法得知遠(yuǎn)程數(shù)據(jù)庫的執(zhí)行情況,此時就會發(fā)生in  doublt的報錯。此時需要dba介入,且需要分多種情況進(jìn)行處理。

Oracle會自動處理分布事務(wù),保證分布事務(wù)的一致性,所有站點(diǎn)全部提交或全部回滾。一般情況下,處理過程在很短的時間內(nèi)完成,根本無法察覺到。

但是,如果在commit或rollback的時候,出現(xiàn)了連接中斷或某個數(shù)據(jù)庫  站點(diǎn)CRASH的情況,則提交操作可能會無法繼續(xù),此時DBA_2PC_PENDING和DBA_2PC_NEIGHBORS中會包含尚未解決的分布事務(wù)。  對于絕大多數(shù)情況,當(dāng)恢復(fù)連接或CRASH的數(shù)據(jù)庫重新啟動后,會自動解決分布式事務(wù),不需要人工干預(yù)。只有分布事務(wù)鎖住的對象急需被訪問,鎖住的回滾段阻止了其他事務(wù)的使用,網(wǎng)絡(luò)故障或CRASH的數(shù)據(jù)庫的恢復(fù)需要很長的時間等情況出現(xiàn)時,才使用人工操作的方式來維護(hù)分布式事務(wù)。  手工強(qiáng)制提交或回滾將失去二層提交的特性,Oracle無法繼續(xù)保證事務(wù)的一致性,事務(wù)的一致性應(yīng)由手工操作者保證

使用ALTER SYSTEM DISABLE DISTRIBUTED  RECOVERY,可以使Oracle不再自動解決分布事務(wù),即使網(wǎng)絡(luò)恢復(fù)連接或者CRASH的數(shù)據(jù)庫重新啟動。

ALTER SYSTEM ENABLE DISTRIBUTED RECOVERY恢復(fù)自動解決分布事務(wù)。

兩個重要的視圖

1. DBA_2PC_PENDING

DBA_2PC_PENDING:列出所有的懸而未決的事務(wù)﹐此視圖在末填入懸而未決的事務(wù)之前是空的﹐解決這后也被清空。

Oracle數(shù)據(jù)庫分布式事務(wù)ORA-01591錯誤的解決方法

DBA_2PC_PENDING的STATE列的說明

Oracle數(shù)據(jù)庫分布式事務(wù)ORA-01591錯誤的解決方法

SELECT * FROM DBA_2PC_PENDING;

Oracle數(shù)據(jù)庫分布式事務(wù)ORA-01591錯誤的解決方法

2. DBA_2PC_NEIGHBORS

DBA_2PC_NEIGHBORS:列出所有獲得的(從遠(yuǎn)程客戶)和送出的(給遠(yuǎn)程服務(wù)器)懸而未決的事務(wù)﹐也表示該本地節(jié)點(diǎn)是不是事務(wù)的提交點(diǎn)站點(diǎn)。

Oracle數(shù)據(jù)庫分布式事務(wù)ORA-01591錯誤的解決方法

關(guān)于Oracle數(shù)據(jù)庫分布式事務(wù)ORA-01591錯誤的解決方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI