マルチプロセッサとマルチコンピュータ
この章では、マルチプロセッサとマルチコンピュータについて説明します。
マルチプロセッサシステムの相互接続
並列処理では、入出力デバイスと周辺機器、マルチプロセッサ、および共有メモリ間の高速通信のために、効率的なシステム相互接続を使用する必要があります。
階層型バスシステム
階層型バスシステムは、コンピュータ内のさまざまなシステムおよびサブシステム/コンポーネントを接続するバスの階層で構成されます。各バスは、多数の信号、制御、および電力線で構成されています。ローカルバス、バックプレーンバス、I / Oバスなどのさまざまなバスを使用して、さまざまな相互接続機能を実行します。
ローカルバスは、プリント回路基板に実装されたバスです。バックプレーンバスは、機能ボードを接続するために多くのコネクタが使用されるプリント回路です。入出力デバイスをコンピュータシステムに接続するバスは、I / Oバスと呼ばれます。
クロスバースイッチとマルチポートメモリ
スイッチドネットワークは、入力と出力の間に動的な相互接続を提供します。中小規模のシステムは、主にクロスバーネットワークを使用します。遅延の増加の問題を解決できれば、多段ネットワークをより大規模なシステムに拡張できます。
クロスバースイッチとマルチポートメモリ構成はどちらもシングルステージネットワークです。シングルステージネットワークの構築は安価ですが、特定の接続を確立するには複数のパスが必要になる場合があります。多段ネットワークには、複数のステージのスイッチボックスがあります。これらのネットワークは、任意の入力を任意の出力に接続できる必要があります。
多段ネットワークと結合ネットワーク
多段ネットワークまたは多段相互接続ネットワークは、主にネットワークの一方の端にある処理要素ともう一方の端にあるメモリ要素で構成され、スイッチング要素によって接続された高速コンピュータネットワークのクラスです。
これらのネットワークは、より大規模なマルチプロセッサシステムを構築するために適用されます。これには、オメガネットワーク、バタフライネットワークなどが含まれます。
マルチコンピューター
マルチコンピュータは分散メモリMIMDアーキテクチャです。次の図は、マルチコンピュータの概念モデルを示しています。
マルチコンピュータは、パケット交換方式を適用してデータを交換するメッセージパッシングマシンです。ここでは、各プロセッサにプライベートメモリがありますが、プロセッサは独自のローカルメモリにしかアクセスできないため、グローバルアドレス空間はありません。したがって、通信は透過的ではありません。ここでは、プログラマーは通信プリミティブをコードに明示的に配置する必要があります。
グローバルにアクセス可能なメモリがないことは、マルチコンピュータの欠点です。これは、次の2つのスキームを使用して解決できます-
- 仮想共有メモリ(VSM)
- 共有仮想メモリ(SVM)
これらのスキームでは、アプリケーションプログラマは、グローバルにアドレス指定可能な大きな共有メモリを想定しています。必要に応じて、アプリケーションによって作成されたメモリ参照は、メッセージパッシングパラダイムに変換されます。
仮想共有メモリ(VSM)
VSMはハードウェア実装です。そのため、オペレーティングシステムの仮想メモリシステムは、VSMの上に透過的に実装されます。したがって、オペレーティングシステムは、共有メモリを備えたマシンで実行されていると見なします。
共有仮想メモリ(SVM)
SVMは、オペレーティングシステムレベルでのソフトウェア実装であり、プロセッサのメモリ管理ユニット(MMU)からのハードウェアサポートがあります。ここで、共有の単位はオペレーティングシステムのメモリページです。
プロセッサが特定のメモリ位置をアドレス指定する場合、MMUは、メモリアクセスに関連付けられたメモリページがローカルメモリにあるかどうかを判断します。ページがメモリにない場合、通常のコンピュータシステムでは、オペレーティングシステムによってディスクからページがスワップインされます。ただし、SVMでは、オペレーティングシステムはその特定のページを所有するリモートノードからページをフェッチします。
3世代のマルチコンピューター
このセクションでは、3世代のマルチコンピューターについて説明します。
過去のデザインの選択
マルチコンピューターの設計者は、プロセッサーテクノロジーを選択する際に、ビルディングブロックとして低コストの中粒プロセッサーを選択します。並列コンピューターの大部分は、標準の既製のマイクロプロセッサーで構築されています。マルチコンピュータには、スケーラビリティを制限する共有メモリを使用するのではなく、分散メモリを選択しました。各プロセッサには、独自のローカルメモリユニットがあります。
相互接続スキームの場合、マルチコンピュータには、アドレススイッチングネットワークではなく、メッセージパッシングのポイントツーポイント直接ネットワークがあります。制御戦略については、マルチコンピューターの設計者が非同期MIMD、MPMD、およびSMPD操作を選択します。カリフォルニア工科大学のコズミックキューブ(Seitz、1983)は、第1世代のマルチコンピューターの最初のものです。
現在および将来の開発
次世代コンピュータは、グローバルに共有された仮想メモリを使用して、中粒度から細粒度のマルチコンピュータに進化しました。第二世代のマルチコンピュータは現在も使用されています。しかし、i386、i860などのより優れたプロセッサを使用して、第2世代のコンピュータは多くの開発を行ってきました。
第3世代のコンピューターは、VLSIで実装されたノードが使用される次世代のコンピューターです。各ノードには、14 MIPSプロセッサ、20 Mバイト/秒のルーティングチャネル、および16KバイトのRAMが1つのチップに統合されている場合があります。
インテルパラゴンシステム
以前は、すべての機能がホストに与えられていたため、同種ノードを使用してハイパーキューブマルチコンピューターを作成していました。そのため、これによりI / O帯域幅が制限されました。したがって、大規模な問題を効率的または高スループットで解決するために、これらのコンピューターを使用することはできませんでした。インテルパラゴンシステムは、この困難を克服するように設計されました。マルチコンピュータを、ネットワーク環境でマルチユーザーアクセスが可能なアプリケーションサーバーに変えました。
メッセージパッシングメカニズム
マルチコンピュータネットワークのメッセージパッシングメカニズムには、特別なハードウェアとソフトウェアのサポートが必要です。このセクションでは、いくつかのスキームについて説明します。
メッセージルーティングスキーム
ストアアンドフォワードルーティング方式のマルチコンピュータでは、パケットは情報送信の最小単位です。ワームホールルーティングネットワークでは、パケットはさらにフリットに分割されます。パケット長はルーティングスキームとネットワーク実装によって決定されますが、フリット長はネットワークサイズの影響を受けます。
に Store and forward routing、パケットは情報伝達の基本単位です。この場合、各ノードはパケットバッファを使用します。パケットは、一連の中間ノードを介して送信元ノードから宛先ノードに送信されます。レイテンシーは、送信元と宛先の間の距離に正比例します。
に wormhole routing、送信元ノードから宛先ノードへの送信は、一連のルーターを介して行われます。同じパケットのすべてのフリットは、パイプライン方式で分離できないシーケンスで送信されます。この場合、ヘッダーフリットだけがパケットの行き先を知っています。
デッドロックと仮想チャネル
仮想チャネルは、2つのノード間の論理リンクです。これは、送信元ノードと受信側ノードのフリットバッファ、およびそれらの間の物理チャネルによって形成されます。物理チャネルがペアに割り当てられると、1つのソースバッファが1つのレシーババッファとペアになり、仮想チャネルが形成されます。
すべてのチャネルがメッセージで占有されていて、サイクル内のどのチャネルも解放されていない場合、デッドロック状態が発生します。これを回避するには、デッドロック回避スキームに従う必要があります。