Event Sourcingの設計に出会い、RESTクライアントが必要なアプリケーションで使用したいと思います(正確にはRESTfulです)。ただし、RESTは非常にCRUDに似ており、イベントソーシングはタスクベースであるため、これらを接続することはできません。RESTサーバーへの要求に基づいてコマンドの作成をどのように設計できるのか疑問に思いました。この例を考えてみましょう:
RESTを使用すると、Fileというリソースに新しい状態を設定できます。1つのリクエストで、新しいファイル名を送信したり、親フォルダーを変更したり、ファイルの所有者を変更したりできます。
イベントソーシングを使用できるようにサーバーを構築する方法。私はこれらの可能性について考えていました:
フィールドが変更されたサーバ上で決定し、適切なコマンドを作成する(
RenameFileCommand
、MoveFileCommand
、ChangeOwnerCommand
、...)と個別にこれらを派遣。ただし、このセットアップでは、各コマンドが失敗し、他のリソースがトランザクションから除外され、リソースへの「アトミックな」変更から除外されます。発送のみ一つのコマンド(
UpdateFileCommand
)およびコマンドハンドラでは、より正確に集計では、変更されたフィールドを決定し、代わりに個々のイベントを送信します(FileRenamedEvent
、FileMovedEvent
、OwnerChangedEvent
、...)これはまったく好きではありません:サーバーへのリクエストでは、ヘッダーで使用するコマンドを指定します。UIはまだタスクベースです(ただし、通信はRESTを介して行われます)。ただし、REST通信のその他の使用(外部アプリなど)では失敗します。1つのリクエストで1つのフィールドのみを変更するようにバインドされているためです。また、UI、REST、およびESベースのバックエンドに非常に大きなカップリングをもたらします。
あなたはどちらを好むでしょうか、これを処理するより良い方法はありますか?
サイドノート:イベントソースのためにJavaとAxon Frameworkで書かれたアプリ。