2.3.2 同期点取得
- 〈この項の構成〉
(1) コミット
トランザクションが正常終了したときの同期点取得(コミット)は,CUPからコミット要求のメソッドを呼び出して行います。グローバルトランザクションは,すべてのトランザクションブランチが正常に終了したことで正常終了となります。
(a) 連鎖,非連鎖モードのコミット
トランザクション処理の同期点取得には,一つのトランザクションの終了後,同期点を取得して次のトランザクションを続けて起動する連鎖モードのコミットと,トランザクションの終了で同期点を取得したあと,新たなトランザクションを起動しない非連鎖モードのコミットがあります。
連鎖モードのコミットは,trnChainedCommitメソッドを呼び出して要求します。
非連鎖モードのコミットは,trnUnchainedCommitメソッドを呼び出して要求します。
トランザクションの連鎖,非連鎖モードを次の図に示します。
|
(b) コミット要求のメソッドを呼び出さない場合の処理
コミット要求のメソッドを呼び出さないでCUPが終了したとき,またはコミット要求のメソッドを呼び出す前にCUPが異常終了したときは,トランザクションはロールバックされます。
(2) ロールバック
(a) TP1/Serverの処理がエラーの場合
トランザクションでエラーが発生すると,コミット要求のメソッドがエラーリターンされます。そのトランザクションは部分回復対象としてロールバックされます。グローバルトランザクション内のどれか一つのトランザクションブランチでエラーが発生した場合でも,グローバルトランザクション全体がロールバックの対象となります。このときTP1/Serverは,トランザクションブランチをロールバック対象とみなして,部分回復処理をします。
TP1/Serverの処理でエラーが発生した場合のトランザクションのロールバックを,次の図に示します。
|
(b) ロールバック要求のメソッドの呼び出し
トランザクションをCUPの判断でロールバックしたいときは,CUPからロールバック要求のメソッドを呼び出します。
ロールバックには,連鎖モードのロールバックと非連鎖モードのロールバックがあります。
連鎖モードのロールバックは,trnChainedRollbackメソッドを呼び出して要求します。trnChainedRollbackメソッドを呼び出してロールバックすると,このメソッドを呼び出したCUPのプロセスは,ロールバック処理後も,グローバルトランザクションの範囲内にあります。
非連鎖モードのロールバックは,trnUnchainedRollbackメソッドを呼び出して要求します。trnUnchainedRollbackメソッドを呼び出してロールバックすると,このメソッドを呼び出したCUPのプロセスは,ロールバック処理後,グローバルトランザクションの範囲外となります。
ロールバック要求のメソッドを呼び出した場合のトランザクションのロールバックを,次の図に示します。
|
(3) ヒューリスティック発生時の処置
トランザクション処理でヒューリスティックが発生すると,CUPの同期点取得時にエラーリターンされます。この場合の例外について次に示します。
-
ヒューリスティック決定の結果が,グローバルトランザクションの同期点の結果と一致しなかった場合 … ErrHeuristicException
-
障害のため,ヒューリスティックに完了したトランザクションブランチの同期点の結果が判明しない場合 … ErrHazardException
これらの例外が返される原因,およびグローバルトランザクションの同期点の結果については,TP1/Serverのメッセージログファイルを参照してください。
ヒューリスティック発生時の処置の詳細については,マニュアル「OpenTP1 プログラム作成の手引」を参照してください。
(4) トランザクションの処理時間について
トランザクションに関する,次に示す時間をTP1/Client/J環境定義で指定できます。詳細については「5.2 TP1/Client/J環境定義の詳細」を参照してください。
-
トランザクションブランチ限界経過時間
-
トランザクションブランチの監視時間に,監視対象のトランザクションブランチが,RPC機能を使ってほかのトランザクションブランチを呼び出し,その処理が終わるのを待つ時間を含むかどうか
-
トランザクション問い合わせ間隔最大時間
-
トランザクションブランチCPU監視時間
(5) トランザクションブランチの統計情報取得タイプについて
トランザクションブランチごとに取得するトランザクション統計情報の取得タイプを,TP1/Client/J環境定義で指定できます。詳細については「5.2 TP1/Client/J環境定義の詳細」を参照してください。