Cosminexus ビジネスプロセス管理/エンタープライズサービスバス V8 サービスプラットフォーム 機能解説
![[目次]](FIGURE/CONTENT.GIF)
![[用語]](FIGURE/GLOSS.GIF)
![[索引]](FIGURE/INDEX.GIF)
![[前へ]](FIGURE/FRONT.GIF)
(1) 同期のサービス呼出アクティビティが二つ並んだ場合
- 正常に処理が進行した場合
- それぞれのサービス呼出アクティビティでのメッセージ送信処理直前でトランザクションをコミットし,新たにトランザクションを開始します。
- 同期のサービス呼出で正常に処理が進行した場合のトランザクションの範囲を次の図に示します。
図4-15 正常に処理が進行した場合のトランザクションの範囲(同期のサービス呼出)
![[図データ]](FIGURE/ZC041500.GIF)
- 例外が発生した場合
- サービス呼出2の処理が例外でエラーとなった場合は,トランザクションがコミットした時点(受付:完了状態,サービス呼出1:完了状態,サービス呼出2:実行中状態)までロールバックします。
- 同期のサービス呼出で例外が発生した場合のトランザクションの範囲を次の図に示します。
図4-16 例外が発生した場合のトランザクションの範囲(同期のサービス呼出)
![[図データ]](FIGURE/ZC042100.GIF)
(2) 非同期と同期のサービス呼出アクティビティが二つ並んだ場合
- 正常に処理が進行した場合
- 非同期のサービス呼出アクティビティでのメッセージ送信処理ではトランザクションはコミットしないで,同期のサービス呼出アクティビティでのメッセージ送信処理直前でトランザクションをコミットし,新たにトランザクションを開始します。
- 非同期と同期のサービス呼出で正常に処理が進行した場合のトランザクションの範囲を次の図に示します。
図4-17 正常に処理が進行した場合のトランザクションの範囲(非同期と同期のサービス呼出)
![[図データ]](FIGURE/ZC041600.GIF)
- 例外が発生した場合(非同期と同期のサービス呼出)
- サービス呼出1が非同期,サービス呼出2が同期の構成で,サービス呼出2の処理が例外でエラーとなった場合は,トランザクションがコミットした時点(受付:完了状態,サービス呼出1:完了状態,サービス呼出2:実行中状態)までロールバックします。
- 非同期と同期のサービス呼出で例外が発生した場合のトランザクションの範囲を次の図に示します。
図4-18 例外が発生した場合のトランザクションの範囲(非同期と同期のサービス呼出)
![[図データ]](FIGURE/ZC042200.GIF)
- 例外が発生した場合(同期と非同期のサービス呼出)
- サービス呼出1が同期,サービス呼出2が非同期の構成で,サービス呼出2の処理が例外でエラーとなった場合は,トランザクションがコミットした時点(受付:完了状態,サービス呼出1:実行中状態)までロールバックします。
- 同期と非同期のサービス呼出で例外が発生した場合のトランザクションの範囲を次の図に示します。
図4-19 例外が発生した場合のトランザクションの範囲(同期と非同期のサービス呼出)
![[図データ]](FIGURE/ZC042300.GIF)
(3) 非同期のサービス呼出アクティビティが二つ並んだ場合
- 正常に処理が進行した場合
- 非同期のサービス呼出アクティビティでのメッセージ送信処理ではトランザクションはコミットしません。そのため,ビジネスプロセスが応答するときにトランザクションがコミットします。
- 非同期のサービス呼出で正常に処理が進行した場合のトランザクションの範囲を次の図に示します。
図4-20 正常に処理が進行した場合のトランザクションの範囲(非同期のサービス呼出)
![[図データ]](FIGURE/ZC041700.GIF)
- 例外が発生した場合
- サービス呼出2の処理が例外でエラーとなった場合は,トランザクションがコミットした時点(受付:未実行状態,サービス呼出1:未実行状態,サービス呼出2:未実行状態)までロールバックします。
- 非同期のサービス呼出で例外が発生した場合のトランザクションの範囲を次の図に示します。
図4-21 例外が発生した場合のトランザクションの範囲(非同期のサービス呼出)
![[図データ]](FIGURE/ZC042400.GIF)
(4) 同期のサービス呼出アクティビティのあとにデータ変換アクティビティがある場合
- 正常に処理が進行した場合
- それぞれのサービス呼出アクティビティでのメッセージ送信処理直前でトランザクションをコミットしますが,データ変換アクティビティではトランザクションがコミットしません。これは,表4-7で示した以外のアクティビティも同様です。
- データ変換などのアクティビティがある場合で正常に処理が進行したときのトランザクションの範囲を次の図に示します。
図4-22 正常に処理が進行した場合のトランザクションの範囲(データ変換などのアクティビティがある場合)
![[図データ]](FIGURE/ZC041800.GIF)
- 例外が発生した場合(同期サービス呼出のあとにデータ変換などのアクティビティがある場合)
- サービス呼出1が同期の構成で,サービス呼出1のあとにデータ変換処理でエラーとなった場合は,トランザクションがコミットした時点(受付:完了状態,サービス呼出1:実行中状態)までロールバックします。
- 同期サービス呼出のあとにデータ変換などのアクティビティがある場合で例外が発生したときのトランザクションの範囲を次の図に示します。
図4-23 例外が発生した場合のトランザクションの範囲(同期サービス呼出のあとにデータ変換などのアクティビティがある場合)
![[図データ]](FIGURE/ZC042500.GIF)
- 例外が発生した場合(非同期サービス呼出のあとにデータ変換などのアクティビティがある場合)
- サービス呼出1が非同期の構成で,サービス呼出1のあとにデータ変換処理でエラーとなった場合は,トランザクションがコミットした時点(受付:未実行状態,サービス呼出1:未実行状態)までロールバックします。
- 非同期サービス呼出のあとにデータ変換などのアクティビティがある場合で例外が発生したときのトランザクションの範囲を次の図に示します。
図4-24 例外が発生した場合のトランザクションの範囲(非同期サービス呼出のあとにデータ変換などのアクティビティがある場合)
![[図データ]](FIGURE/ZC042600.GIF)
All Rights Reserved. Copyright (C) 2008, 2011, Hitachi, Ltd.