多層アーキテクチャ
多層アーキテクチャの最新ニュースをまとめて検索!
多層アーキテクチャ(英: Multitier architecture)は、アプリケーションが複数のソフトウェアエージェントによって実行されるクライアントサーバモデルの一形態である。例えば、ユーザーとデータベース間のデータ要求サービスにミドルウェアを利用するアプリケーションは多層アーキテクチャである。最もよく使われる多層アーキテクチャは三層アーキテクチャである。
目次 |
[編集] 三層アーキテクチャ
クライアントサーバモデルにおける「三層」とは、ユーザインタフェース、ビジネスロジック、データベース(およびデータアクセス)であり、それらが独立したモジュールとして開発・保守され、多くの場合それぞれ別のプラットフォーム上で動作する。「三層(three-tier または three-layer)」という用語や「多層アーキテクチャ」という用語はラショナルが起源とされている[要出典]。
三層モデルは、ソフトウェアアーキテクチャであると同時にデザインパターンでもある。
インタフェースを正しく定義したモジュール化されたソフトウェアという意味での利点だけでなく、三層アーキテクチャはテクノロジーの進歩や要求に合わせて各層を個別に置換できる。例えばクライアントのオペレーティングシステムを Microsoft Windows から UNIX に変更しても、それはユーザインタフェース層にしか影響しない。
ユーザインタフェースは、デスクトップPCやワークステーション上で標準のGUIを使って動作するのが一般的である。ビジネスロジックは1つ以上のモジュールで構成され、ワークステーションやアプリケーションサーバ上で動作する。データベースにはサーバやメインフレーム上のRDBMSが使われる。中間層自体が多層化されることもある。
三層アーキテクチャでの各層の名称は以下の通り。
- プレゼンテーション層
- アプリケーション層/ロジック層/ビジネスロジック層/トランザクション層
- データ層
[編集] MVCアーキテクチャとの比較
一見したところ、三層アーキテクチャは Model View Controller (MVC) に似ている。しかしトポロジー的には異なっており、適用分野も異なる。三層アーキテクチャの基本原則として、プレゼンテーション層は決してデータ層と直接通信しない。つまり、全ての通信は必ず中間層を通る。従って、三層は一本の直線で表される。それに対して MVC では 3つがそれぞれ相互に通信するため、三角形を形成している。三層アーキテクチャはデータベースとユーザーの間の情報経路を表しているのに対して、MVC はユーザインタフェースにおける画面上のコンポーネントの管理方法を表している。MVC に基づくコンポーネントは、三層アーキテクチャのアプリケーションでもよく使われる。
歴史的に見れば、三層アーキテクチャは1990年代に生まれた。これは、Webアプリケーションなどの分散システムにおいて、クライアント、ミドルウェア、データベースの3者がそれぞれ物理的に別のプラットフォームで動作するようになったことから生じたものである(つまり、実装が先にあって、後から概念として抽象化された)。一方、MVC は1980年代(パロアルト研究所での1970年代末から1980年代初期にかけてのこと)に、1つのグラフィカルワークステーション上で動作するアプリケーション群の仕組みから生まれた。MVC が分散アプリケーションに適用される(コンテンツとプレゼンテーションの分離がされた)のはもっと後のことである。
[編集] Web開発での利用
Web開発の分野では、三層モデルはウェブサイト、特に電子商取引のウェブサイトの構成の説明に使われる。その場合、各層は以下のようになる。
- プレゼンテーション層: 変化しないコンテンツを供給するWebサーバ
- 中間層: 動的コンテンツを生成するアプリケーションサーバ。例えば Java EE プラットフォームなど。
- データ層: データベースとその管理システム。RDBMS など。
[編集] 関連項目
- ウェブアプリケーション
- ビジネスロジック
- リッチインターネットアプリケーション (RIA)
- クライアントサーバモデル
- フロントエンド
- Model View Controller (MVC)
- SAP R/3 は三層モデルを使ったクライアントサーバ型アプリケーションである。
[編集] 参考文献
- Erik Meijer and Danny van Velzen (2001年). “Haskell Server Pages Functional Programming and the Battle for the Middle Tier” (PDF). Electronic Notes in Theoretical Computer Science 41 (1).
- "Three Tier Software Architectures" (HTML). 2008年2月7日 閲覧。
- "MVC XEROX PARC 1978–79" (HTML). 2008年2月7日 閲覧。
この記述は GNU Free Documentation License のもとに公開されているコンピュータ用語辞典『 Free On-line Dictionary of Computing (FOLDOC) 』に基づいています。
最終更新 2009年9月23日 (水) 00:43 (日時は個人設定で未設定ならばUTC)。
【多層アーキテクチャ】変更履歴

