成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解Oracle數據庫分布式事務ORA-01591錯誤解決方法

數據庫 Oracle 分布式
最近在update某張表時突然提示了個比較少見的錯誤,ORA-01591,這個問題跟平時的鎖還有點不一樣,下面一起來看看吧。

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

詳解Oracle數據庫分布式事務ORA-01591錯誤解決方法

思路

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

  1. select * from gv$locked_object; 
  2. select * from gv$transaction; 

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

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

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

處理方法

  1. rollback force '20.13.14721'; 

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

處理還是比較簡單的,這里順便分享下分布式事務的相關知識點。

分布式事務相關知識點

分布式事務,簡單來說,是指一個事務在本地和遠程執行,本地需要等待確認遠程的事務結束后,進行下一步本地的操作。如通過dblink update遠程數據庫的一行記錄,如果在執行過程中網絡異常,或者其他事件導致本地數據庫無法得知遠程數據庫的執行情況,此時就會發生in doublt的報錯。此時需要dba介入,且需要分多種情況進行處理。

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

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

使用ALTER SYSTEM DISABLE DISTRIBUTED RECOVERY,可以使Oracle不再自動解決分布事務,即使網絡恢復連接或者CRASH的數據庫重新啟動。

ALTER SYSTEM ENABLE DISTRIBUTED RECOVERY恢復自動解決分布事務。

兩個重要的視圖

1. DBA_2PC_PENDING

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

詳解Oracle數據庫分布式事務ORA-01591錯誤解決方法

DBA_2PC_PENDING的STATE列的說明

詳解Oracle數據庫分布式事務ORA-01591錯誤解決方法

SELECT * FROM DBA_2PC_PENDING;

詳解Oracle數據庫分布式事務ORA-01591錯誤解決方法

2. DBA_2PC_NEIGHBORS

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

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2011-08-22 18:12:20

OracleORA-01591

2019-08-19 10:24:33

分布式事務數據庫

2019-10-10 09:16:34

Zookeeper架構分布式

2023-08-27 16:11:35

數據庫分布式事務數據庫

2018-06-07 08:31:33

Oracle分布式內存

2015-06-16 10:39:43

NoSQL分布式算法

2022-08-01 18:33:45

關系型數據庫大數據

2019-06-10 14:31:24

MySQL存儲數據庫

2011-05-16 09:54:22

mysql1067錯誤

2010-06-30 17:27:32

SQL Server數

2022-03-24 07:51:27

seata分布式事務Java

2025-04-29 04:00:00

分布式事務事務消息

2009-12-18 11:03:45

Ruby watir環

2013-08-13 13:38:13

Android錯誤解決

2022-07-10 20:24:48

Seata分布式事務

2010-05-06 10:01:25

Oracle數據庫

2011-08-29 14:33:02

Oracle存儲過程

2011-08-12 13:33:31

Oracle數據庫自治事務

2021-11-08 10:52:02

數據庫分布式技術

2022-06-27 08:21:05

Seata分布式事務微服務
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美日本一区 | 欧美精品一二三 | 美日韩中文字幕 | 欧美综合久久 | 久久lu| 国产精品久久久久久久久免费桃花 | 91成人在线 | 国产精品久久久久久久一区探花 | 成人一区二区三区在线观看 | 综合色导航 | 欧美网站一区 | 一级一级毛片免费看 | 国产精品乱码一二三区的特点 | 国产成人精品久久久 | 欧美日韩1区2区 | 国产精品不卡 | 欧美一级欧美三级在线观看 | 国产一级大片 | 国产极品车模吞精高潮呻吟 | 一区二区免费在线观看 | 黄色免费在线观看网址 | 91大神xh98xh系列全部 | 伊人网站| 日韩精品 | 午夜精品久久久久久久99黑人 | 一区二区三区亚洲视频 | 懂色中文一区二区三区在线视频 | 91久久北条麻妃一区二区三区 | 久久国产激情视频 | 91精品国产综合久久福利软件 | 国产有码| 欧美日韩国产精品激情在线播放 | 成年网站在线观看 | 精品一区二区三区不卡 | sese视频在线观看 | 一级毛片,一级毛片 | 日韩在线不卡 | 精品综合视频 | 亚洲国产精品久久 | 中文字幕在线电影观看 | 久久伊人亚洲 |