いくつかの質問への回答で、Jonathan Oliver は AsynchronousCommitDispatcher を使用して複数の作業単位を処理することについて言及しています。
私はまだプロジェクトの設計段階にあり (そしてまだ CRQS と ES を学んでいます)、いくつか質問があります。
発生するドメイン イベントの影響を受ける集約ルートごとに AsynchronousCommitDispatcher を作成しますか?
別のユーザーによってロックされている場合、ディスパッチされたイベントが集約ルートに変更を加えることができない、ある種のロック メカニズムがある場合はどうなりますか? ロックがある場合、AsynchronousCommitDispatcher は再試行しますか?
ドメイン イベントが処理される前にシステムがダウンした場合はどうなりますか? 未処理であることに固執しなければ、失われてしまうのでしょうか?
私の最初の理解では、Dispatcher のタイプは、ネットワークを介したメッセージングまたは読み取りモデルの更新用でした。ここでは、別の集約ルートを更新するために使用しています。私はこれが正しいですか?
ティア
JD