BPEL-障害処理の使用

障害処理の使用方法を理解するには、Oracle SOASuiteのServiceCompositeの基本アーキテクチャを学習する必要があります。

  • Service components− BPELプロセス、ビジネスルール、ヒューマンタスク、メディエーター。これらは、SOA複合アプリケーションを構築するために使用されます。

  • Binding components −SOAコンポジットと外部世界の間の接続を確立します。

  • Services −SOA複合アプリケーションへのエントリポイントを提供します。

  • Binding − SOAP / HTTP、JCAアダプターなどのサービスと通信するプロトコルを定義します。

  • WSDL −Webサービスのサービス定義を定義します。

  • References −SOA複合アプリケーションが外部サービスにメッセージを送信できるようにします

  • Wires −サービスコンポーネント間の接続を有効にします。

障害の種類

ここで、さまざまなタイプの障害を見てみましょう。

ビジネス上の欠点

アプリケーションがTHROWアクティビティを実行するか、INVOKEが応答として障害を受信したときに発生します。障害名は、BPELプロセスサービスコンポーネントによって指定されます。障害名と障害変数を使用する障害ハンドラーは、この障害をキャッチします。

ランタイム障害

これはシステムによってスローされます。これらの障害はに関連付けられていますRunTimeFaultMessage に含まれています

http://schemas.oracle.com/bpel/extensionnamespace

障害処理の方法

このセクションでは、障害処理のさまざまな方法について学習します。

スローアクティビティ

スローアクティビティは明示的に障害をスローします。catchブロックはこの障害をキャッチし、対応するアクションがそれによって実行されます。

  • スローアクティビティを使用すると、ビジネスフォールトをスローでき、作成されたスコープ内で、このフォールトをキャッチし、呼び出し元(コンシューマー)にリダイレクトしてアクションを実行できます。

  • 上記のアプローチの代わりに、作成されたスコープのcatchアクティビティでキャッチされたのと同じフォールトをスローします。メインスコープでは、catchallアクティビティを使用してこの障害をキャッチできます。

エラーハンドラフレームワーク(EHF)

EHFで使用される2つの主要なファイルは次のとおりです。

  • Fault-Policy.xml
  • Fault-Bindings.xml

BPELプロセスがエラーをスローするたびに、EHFはエラーがFault-Bindings.xmlファイルに存在するかどうかをチェックします。その場合、Fault-Policy.xmlファイルのアクションが実行されます。アクションが見つからない場合、障害がスローされ、catchブロックで処理されます。

障害管理フレームワーク(Fault-Policy.xmlおよびFault-Bindings.xml)は、SOAコンポジット内に保持されます。

catchやcatchallなどのフォールトハンドラーは、すべてのフォールトをキャッチするためにBPEL内にありますが、 fault policies will only be executed when an invoke activity fails.