亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

怎么處理ORACLE懸疑分布式事務問題

發布時間:2021-11-05 10:41:49 來源:億速云 閱讀:216 作者:iii 欄目:關系型數據庫

這篇文章主要講解了“怎么處理ORACLE懸疑分布式事務問題”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么處理ORACLE懸疑分布式事務問題”吧!

當需要在多個Oracle數據庫之間進行數據一致性操作時,就會用到分布式事務。
例如:

insert into T_log@remote_db;  --遠程數據庫插入
insert into T_local;          --本地數據庫插入
commit;

分布在本地和遠程兩個db的事務同時操作,這就構成了一個分布式事務。

分布式事務采用Two-Phase Commit提交機制,保證分布在各個節點的子事務能夠全部提交或全部回滾的原子性。在這種機制下,事務處理過程分為三個階段:

  1. PREPARE:發起分布式事務的節點通知各個關聯節點準備提交或回滾。各關聯節點此時會做三個事情:刷新redo信息到redo log中;將持有的鎖轉換為懸疑事務鎖;取各節點中最大的SCN號進行同步

  2. COMMIT:寫入commited SCN,釋放鎖資源

  3. FORGET:懸疑事務表和關聯的數據庫視圖信息清理

由于分布式事務涉及到多個數據庫之間進行操作,偶爾會遇到一些異常情況(例如系統或網絡中斷)導致上述三個階段出現異常,這就在一個或多個節點上,產生不完整的“懸疑分布式事務”。
大多數情況下,出現這種問題,Oracle會由Reco進程進行自動修復,Oracle數據庫會在dba_2pc_pending 和dba_2pc_neighbors等多個視圖中記錄分布式事務相關的信息,事實上reco進程也是基于這些信息去做自動修復的。
Reco進程會嘗試連接到其他節點獲取分布式事務信息,然后嘗試修復失敗的事務,并將對應的事務中的記錄刪除。
但有些情況下(例如節點無法正常訪問或事務表中記錄的數據不完整),Reco進程不能正常完成這個工作,就會拋出異常。對于分布式事務,對應的異常代碼區間是ORA-02040 - ORA-02099,可通過alert日志查看到錯誤信息。
例如:

ORA-02054: transaction in-doubt
The transaction is neither committed or rolled back locally, and we have lost communication with the global coordinator.

此時往往需要手工處理進行干預。

以下是三種常見的分布式事務問題場景:

  1. dba_2pc視圖中有數據,但分布式事務已經不存在

  2. 分布式事務存在,但dba_2pc視圖中沒有數據

  3. 事務和視圖數據都有,但是執行commit force或rollback force時hang住

通過報錯會有提示,例如:

ORA-01591: lock held by in-doubt distributed transaction 10.20.360
這個10.20.360就是我們需要檢查分布式事務ID

場景一:dba_2pc視圖中有數據,但分布式事務已經不存在
視圖有數據,那么先檢查數據的狀態

select * from dba_2pc_pending where local_tran_id='10.20.360';

主要看state字段。
如果事務已經是committed, rollback forced或者commit forced狀態,表示事務已經完成了,但是在FORGET階段處理時,數據庫字典的信息沒能及時清除。此時,我們調用oracle的清理丟失事務信息的語句就可以完成處理:

execute DBMS_TRANSACTION.PURGE_LOST_DB_ENTRY ('10.20.360');

如果事務是PREPARED狀態,但是在事務表中又沒有活動的事務:

SELECT KTUXEUSN, KTUXESLT, KTUXESQN, /* Transaction ID */
KTUXESTA Status,
KTUXECFL Flags
FROM x$ktuxe
WHERE ktuxesta!='INACTIVE'
AND ktuxeusn= 10;   --注意替換這里的回滾段號(xid=usn.slot.(sqn+1))
----沒有活動的事務

那此時需要手工清理丟失事務的信息

set transaction use rollback segment SYSTEM;
delete from sys.pending_trans$ where local_tran_id = ;
delete from sys.pending_sessions$ where local_tran_id = ;
delete from sys.pending_sub_sessions$ where local_tran_id = ;
commit;

場景二:分布式事務存在,但dba_2pc視圖中沒有數據

遇到ORA-2054, ORA-1591等錯誤,檢查dba_2pc視圖沒有記錄,這種場景不常見,只在少數極端的情況下出現。
先確認現象,分別檢查x$ktuxe和 dba_2pc_pending視圖,查詢語句與場景一相同
在這種情況下無論是執行commit force還是rollback force,都會直接拋出異常:

 commit force '10.20.360';
 ORA-02058: no prepared transaction found with ID 10.20.360

這時我們需要將視圖對應的基表數據補入,然后再執行rollback force。

  alter system disable distributed recovery;
  insert into pending_trans$ (
    LOCAL_TRAN_ID, GLOBAL_TRAN_FMT,
    GLOBAL_ORACLE_ID,STATE, STATUS,
    SESSION_VECTOR,RECO_VECTOR,TYPE#, FAIL_TIME, RECO_TIME)
    values( '10.20.360', /* <== Replace this with your local tran id */
    306206, 'xxxxxxxx.00000.0.0.0', 
    'prepared','P', 
    hextoraw( '00000001' ),hextoraw( '00000000' ), 0, sysdate, sysdate );
  insert into pending_sessions$ 
    values( '10.20.360',1, hextoraw('00000000'), 'C', 0, 1433927502, '', 14);
    --1433927502為DBID, 14為userid
  commit;
  rollback force '10.20.360';
  EXECUTE DBMS_TRANSACTION.PURGE_LOST_DB_ENTRY('10.20.360'); 
  --手工清理事務信息

場景三:事務和視圖數據都有,但是執行commit force或rollback force時hang住

如果視圖和事務表中都有數據,而且狀態是PREPARED,先執行commit force或rollback force,通常就能解決問題,但有時候也會遇到執行force處理時hang住
嘗試purge事務信息時,有提示報錯:

BEGIN DBMS_TRANSACTION.PURGE_LOST_DB_ENTRY('10.20.360'); END; 
* 
ERROR at line 1: 
ORA-06510: PL/SQL: unhandled user-defined exception 
ORA-06512: at "SYS.DBMS_TRANSACTION", line 94 
ORA-06512: at line 1

此時需要進行場景一和場景二的結合起來的所有步驟:

1. 先將視圖對應的基表數據刪除
   delete from sys.pending_trans$ where local_tran_id = '10.20.360'; 
   delete from sys.pending_sessions$ where local_tran_id = '10.20.360'; 
   delete from sys.pending_sub_sessions$ where local_tran_id ='10.20.360'; 
   commit;
2. 再插入pending_trans$和pending_sessions$數據,見場景二
3. rollback force '10.20.360'; 
4. Purge the transaction: 
   exec dbms_transaction.purge_lost_db_entry('10.20.360');

感謝各位的閱讀,以上就是“怎么處理ORACLE懸疑分布式事務問題”的內容了,經過本文的學習后,相信大家對怎么處理ORACLE懸疑分布式事務問題這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

西林县| 扶风县| 即墨市| 溧阳市| 越西县| 门源| 淮滨县| 黑水县| 临夏县| 宕昌县| 綦江县| 清远市| 海宁市| 东兰县| 津市市| 自贡市| 西城区| 莒南县| 澄江县| 怀来县| 衡南县| 荆州市| 岳阳县| 元谋县| 曲松县| 隆昌县| 孝感市| 河源市| 石狮市| 大邑县| 泰兴市| 晋州市| 兴海县| 抚州市| 鄂托克前旗| 广灵县| 蓝田县| 睢宁县| 靖边县| 浮梁县| 南丹县|