このシナリオは、当社の顧客で実装したシナリオと非常によく似ています。
しかし、あなたは別の方法で問題について考える必要があります。 Camundaまたはその前身エンジン(Activiti)のどちらも、私が「耐久性のある」メッセージという用語を好むものを扱うことはできません。 「耐久性のある」メッセージは、エンジンが来てそのエンジンを探すまでエンジン内で持続するメッセージです。一般に、JMSなどのpub/sobメッセージプラットフォームを使用している場合、これは問題ではありません。しかし、tcp経由でhttp経由で通信している場合は、メッセージが間違っているか失われている可能性があるので、面倒なことがあります。
したがって、私は、あなたがtcp上でhttpを使ってnを計画していると仮定しています(あなたの説明に基づいて)。
メッセージを失うことがないように、「ループ」パラダイムを放棄する必要があります。ループを使用すると、メッセージが入ったときにプロセスインスタンスが受信タスクを待つことを保証できません。
ループを使用するのではなく、ループを使用するのではなく、メッセージ開始イベントの場合、メッセージ開始イベントには、関連するインスタンス間の相関関係として機能するビジネスデータキーが含まれます。
基本的な流れは以下の通りです:流れは非常にシンプルであることを
はお知らせ、メッセージを受け取り、非同期呼び出しを行い、終了した後、成功メッセージを待ちます。
着信メッセージがリストタスクの終了かどうかを判断する判断ゲートウェイがあります。これが検出された場合、分岐し、同じ相関キーを使用してアクティブなインスタンスに照会し、インスタンスtiが失敗または完了するのを待ちます。完了すると、最終タスクプロセスインスタンスが完了し、適切な監査証跡が更新されます。
インスタンスANYの完了時に失敗すると、「最終タスク」インスタンスがエラー状態を処理します。
ありがとう、グレッグ!それは私にとって非常に良い出発点です。 –
心配はありませんPelykh、あなたが受け入れられ、upvoteとして回答者を設定することができれば私は本当に感謝します。 –