簡介
取決于上下文, XA 有多種意思. 我們常見的數據庫連接交易中的 XA 是指由 X/Open 組織提出的分布式交易處理的規範. XA 規範主要定義了事務管理器(Transaction Manager)和局部資源管理器(Local Resource Manager)之間的接口。
有人說 XA 是 eXtended Architecture 的縮寫, 其實我覺得這僅僅是一種巧合. eXtended Architecture 是一種CD ROM的驅動架構。
操作
以下的函數使事務管理器可以對資源管理器進行的操作:
1)xa_open,xa_close:建立和關閉與資源管理器的連接。
2)xa_start,xa_end:開始和結束一個本地事務。
3)xa_prepare,xa_commit,xa_rollback:預提交、提交和回滾一個本地事務。
4)xa_recover:回滾一個已進行預提交的事務。
5)ax_開頭的函數使資源管理器可以動态地在事務管理器中進行注冊,并可以對XID(TRANSACTION IDS)進行操作。
6)ax_reg,ax_unreg;允許一個資源管理器在一個TMS(TRANSACTION MANAGER SERVER)中動态注冊或撤消注冊。
接口詳解
XA接口是雙向的系統接口,在事務管理器(Transaction Manager)以及一個或多個資源管理器(Resource Manager)之間形成通信橋梁。
事務管理器控制着JTA事務,管理事務生命周期,并協調資源。在JTA中,事務管理器抽象為javax.transaction.TransactionManager接口,并通過底層事務服務(即JTS)實現。資源管理器負責控制和管理實際資源(如數據庫或JMS隊列)。