この記事の内容:ソフトウェアアーキテクチャの概要と選択
-
上司から任られたプロジェクトについて「アーキテクチャについてざっくり考えてきてください」といわれたとき
-
そもそもどんなアーキテクチャが世の中にあるのか
-
新米アーキテクトとしてどうすればいいかわからないとき
特に、アーキテクトスタイル(アーキテクチャパターン)のことについて
参考:fundamentals of software architecture pdf
アーキテクチャを学ぶ意味
アーキテクチャとは
世間一般の会話の流れだと以下のような図面のこと
そしてソフトウェアの歴史の中で、幾度か同じようなパターンが出てくることがあり、中には名前がつくほど有名になるものがある。
たとえば、Eclipseのようなプラグインによって機能を拡張するタイプには、 「プラグインアーキテクチャ」あるいは「マイクロカーネルアーキテクチャ」 という名前がつく。
このようなアーキテクチャのパターンの名前を、**「アーキテクチャスタイル」**と呼ぶ。
アーキテクチャスタイルを覚える意味
経験豊富なアーキテクト同士の表現方法として機能します。
イベント駆動の意味よりはマイクロサービスとしてコンポーネントを置いておきたい
このコンポーネントはメディエーターとして機能するね
「コンポーネント」とは「システムの構成要素」のこと。サーバーレベルだったりコンテナレベルだったりクラスレベルだったりする。どの程度の粒度になるかは文脈に依存する。
見習うべきではないスタイル:巨大な泥団子
内部構造を持たず、イベントハンドラがデータベースの呼び出しまでを行ってしまっているようなスクリプティングアプリケーション
現実の世界ではよく見られる。
このスタイルはいわば反面教師で、きちんとアーキテクチャを考慮しないとクラスの変更の余波の予測が困難になり、関心ごとを分離することができなくなるという教訓をもたらしてくれる。
補足:なぜアーキテクチャを決めるのか?
ここは感想だが、「クラスの変更の余波の予測が困難になり、関心ごとを分離することができなくなる」というのはコードの品質を保つための脅し文句にもなると思う
リファクタリングを怠るPMに向かって、「将来的にクラスの変更の余波の予測が困難になり、関心ごとを分離することができなくなるがそれでも良いですか?」といえば考慮はしてくれる(気がする)
基本的なアーキテクトスタイル一覧
それではアーキテクチャの一覧を見ていく。
今回は7種類のアーキテクチャについて触れる。
- レイヤードアーキテクチャ
- パイプラインアーキテクチャ
- マイクロカーネルアーキテクチャ
- サービスベースアーキテクチャ
- イベント駆動アーキテクチャ
- スペースベースアーキテクチャ
- マイクロサービスアーキテクチャ
アーキテクチャを選択する
新しいシステムを作成するとき、あるいは今あるシステムを改築するとき、アーキテクトそのものを見直す時がある。
アーキテクチャスタイルの選択の際には次のような設問がある
- 分散アーキテクチャかモノシリックか
アーキテクチャの選択:モノシリックアーキテクチャと分散アーキテクチャ
モノシリックとは以下のアーキテクチャのこと。単一でシンプルだが弾力性やパフォーマンスは一定しか出せない。
分散アーキテクチャとは以下のアーキテクチャのこと
モノシリックアーキテクチャと分散アーキテクチャのメリットデメリット
現代では分散アーキテクチャの方が以下の点で優秀だ
-
パフォーマンス
-
スケーラビリティ
-
可用性
しかしこれにも一つの大きなトレードオフがある
それがネットワークを基盤とするために起こる不安定性
例えば
-
途中でパケットが途切れることを考慮したコンポーネントをエンドポイントのロジックに与えなければならない
-
ネットワーク自体は絶えず変化する
-
ネットワークの帯域幅は無限ではない
などなど
アーキテクチャ一覧
小規模かつ低予算:レイヤードアーキテクチャ
このアーキテクチャはシンプルさや親やすさ、コストの低さからほとんどのアプリケーションのスタンダードの形となっている。
とにかくシステムの拡張性を高くしたい:マイクロカーネルアーキテクチャ
プラグインアーキテクチャの用途は大きく分けて2種類あり、
-
パッケージ化され、単一のモノシリックなアプリとしてダウンロードされてインストールできるようなアプリケーション
-
カスタムビジネス(国ごとのローカライズが発生するなど)アプリケーション
このいずれかで使用される。
ユーザー数のバーストに耐えれるようにしたい:スペースベースアーキテクチャ
スペースベースアーキテクチャの特徴は、アプリの標準的なトランザクションに中央のデータベースが関与しないことです。
これにより、データベースのトランザクションというボトルネックが解消されアプリケーションのスケーラビリティは無限になります。
中央のデータベースとの連携ではなく、各処理ユニットがメモリ内部にデータを持つのです。
そして、メモリ内部のデータが更新されると、更新情報が非同期的に他の処理ユニットに送られ、結果的に複製されます。
これらのメモリ内部でのデータ共有の技術をタプルスペースと呼ぶのです。
スペースベースのアーキテクチャのスペースとは、タプルスペースに由来します。
中央データベースをシステムの同期制約として削除し、代わりに複製されたメモリ内データグリッドを活用することで、高いスケーラビリティ、高い弾力性、および高いパフォーマンスが実現されます。
ユニット処理装置は、ユーザーの負荷が増減するにつれて動的に起動およびシャットダウンするため、スケーラビリティーが確保されるのです。
応答速度が早いシステム:イベント駆動アーキテクチャ
イベント駆動アーキテクチャは高度にスケーラブル(弾力性が高い)で高パフォーマンスなアプリケーションを実現できるアーキテクチャです。
また、適応性に優れており、小規模なアプリにも大規模なアプリにも使うことができるのも特徴です。
シンプルなドメイン駆動開発:サービスベースアーキテクチャ
サービスベースアーキテクチャは、マイクロサービスアーキテクチャの要素もある、分散型のアーキテクチャだ。
しかし、マイクロサービスやイベント駆動のタイプに見受けられる複雑さやコストがなく、多くのビジネスアプリケーションで選択されている。
大規模なドメイン駆動開発:マイクロサービスアーキテクチャ
マイクロサービスのコアな価値観は疎な結合による高度な分離です。
各サービスでは、会社がやりたい事業をそのままシステム化しています。
例えば、ECサイトをマイクロサービス化する場合、注文受付サービス、在庫管理サービス、物量管理サービスの3つがマイクロサービスとしてひとつの仕事と責任をこなします。
そして、注文受付サービスの変更は在庫管理サービスに影響しないようにするのです。
そのような高度な分離による変更可能性こそがマイクロサービスアーキテクチャの真価です。
データ変換に特化したい:パイプラインアーキテクチャ
パイプとフィルターのそれぞれの一方向性とシンプルさは、構成の再利用を促す。
特に、powershellやbashシェル、関数型プログラミングに触れたことがある人ならばその威力を把握しているだろう。
まとめ
アーキテクトは常にトレードオフである
備考
title:アーキテクチャスタイル一覧
description:アーキテクトを学ぶ意義の理解。特に、アーキテクトスタイル(アーキテクチャパターン)のことについて。アーキテクトスタイルとは、さまざまなアーキテクチャ特性をカバーする、コンポーネント同士の名付けられた関係を説明するもの。
category_script:page_name.startswith("2")
img:https://cdn.mainichi.jp/vol1/2018/02/26/20180226oog00m010037000p/9.jpg?1