イベントソーシングパターンとは

イベントソーシングパターンとは、アプリケーションの状態をイベントの不変なシーケンスとして保存する設計パターンのことです。

従来のCRUD(Create、Read、Update、Delete)モデルとは異なり、データの状態を直接更新するのではなく、状態の変化を表すイベントを記録していきます。

イベントソーシングの概念

  • イベント: システム内で発生した状態の変化を表す不変の記録。例えば、「商品が購入された」「ユーザーが登録された」などがイベントとして記録されます。
  • イベントストア: イベントを永続的に保存するためのデータストア。
  • 集約: 関連するイベントのグループ。例えば、「顧客」集約には、「顧客が登録された」「顧客情報が更新された」などのイベントが含まれます。プロジェクション: イベントストリームを処理して、現在の状態や特定のビューを生成するプロセス。

イベントソーシングの仕組み

  1. コマンド: アプリケーションは、状態を変更するためのコマンドを発行します(例:CreateUserCommand)。
  2. イベント: コマンドハンドラは、コマンドを処理し、対応するイベントを生成します(例:UserCreatedEvent)。
  3. 保存: 生成されたイベントは、イベントストアに保存されます。
  4. プロジェクション: イベントが発生するたびに、プロジェクションが実行され、現在の状態やビューが更新されます。

関連用語

マイクロサービスアーキテクチャ | 今更聞けないIT用語集
クラウドネイティブ | 今更聞けないIT用語集
リファクタリング

お問い合わせ

システム開発・アプリ開発に関するご相談がございましたら、APPSWINGBYまでお気軽にご連絡ください。

APPSWINGBYの

ソリューション

APPSWINGBYのセキュリティサービスについて、詳しくは以下のメニューからお進みください。

システム開発

既存事業のDXによる新規開発、既存業務システムの引継ぎ・機能追加、表計算ソフトによる管理からの卒業等々、様々なWebシステムの開発を行っています。

iOS/Androidアプリ開発

既存事業のDXによるアプリの新規開発から既存アプリの改修・機能追加まで様々なアプリ開発における様々な課題・問題を解決しています。


リファクタリング

他のベンダーが開発したウェブサービスやアプリの不具合改修やソースコードの最適化、また、クラウド移行によってランニングコストが大幅にあがってしまったシステムのリアーキテクチャなどの行っています。