BT

InfoQ ホームページ ニュース IODAアーキテクチャについて

IODAアーキテクチャについて

ブックマーク

原文(投稿日:2015/05/27)へのリンク

Ralf Westphal氏によると、レイヤードアーキテクチャヘキサゴナルアーキテクチャクリーンアーキテクチャといったアーキテクチャパターンはみな同じ2つのことをしていて、よく似ているという。その2つとは、責務領域の定義と機能的依存関係の整理だ。これらのパターンは、アプリケーションの構造について非常に大雑把なイメージを与えてくれる。基本的に、これらは機能や振る舞いの依存関係を、ひとつの難解な階層構造として記述する。

Westphal氏はアーキテクチャを記述する別の方法を求めて、IODAアーキテクチャというスタイルを定義した。これは振る舞いの責務に直交する3つのフォーマルな責務を用いる。

IODA Architecture オペレーション(Operation):何らかのデータを扱うロジックや振る舞いだが、他のオペレーションのことを知らず、呼び出すことも許されていない。
データ(Data):データの構造であり、一貫性を保証するためにそのデータを扱うサービスを含んでもよいが、どんな形式のロジックも含まない。
インテグレーション(Integration):オペレーションと他のインテグレーションを呼び出して、すべてをまとめる。これによって振る舞いを生み出すが、ロジックを含まない。
APIおよびフレームワーク:これを通じてオペレーションは環境とやりとりする。

このモデルでは、オペレーションはデータにのみ依存し、インテグレーションはオペレーションと他のインテグレーションに依存する。これによって、機能的依存関係はすべて取り除かれるとWestphal氏は言う。そして残ったものが、フォーマルあるいは空の依存関係と呼ぶものになる。また、オペレーションは他のオペレーションを呼び出せないため、ロジックを新しいオペレーショナルメソッドに抽出することは、まとめるためのインテグレーションを作成し、アプリケーションに10-20行以下の小さなメソッドを作ることになる。

重要なところは、IODA構造は複数のレベルに見られるということだ。ある抽象レベルのオペレーションをズームインすると、それ自体が完全なIODA構造になりえるということだ。

Westphal氏はIODAを使った小さなアプリケーションの設計および実装例を作った。これには設計の背後にある基本的な考え方の説明が含まれており、コードをダウンロードすることができる。

この記事に星をつける

おすすめ度
スタイル

こんにちは

コメントするには InfoQアカウントの登録 または が必要です。InfoQ に登録するとさまざまなことができます。

アカウント登録をしてInfoQをお楽しみください。

HTML: a,b,br,blockquote,i,li,pre,u,ul,p

コミュニティコメント

HTML: a,b,br,blockquote,i,li,pre,u,ul,p

HTML: a,b,br,blockquote,i,li,pre,u,ul,p

BT

あなたのプロファイルは最新ですか?プロフィールを確認してアップデートしてください。

Eメールを変更すると確認のメールが配信されます。

会社名:
役職:
組織規模:
国:
都道府県:
新しいメールアドレスに確認用のメールを送信します。このポップアップ画面は自動的に閉じられます。