This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision Next revision Both sides next revision | ||
自作クラスタ計算機:mpiによる並列計算 [2020/03/02 17:35] koudai |
自作クラスタ計算機:mpiによる並列計算 [2020/03/03 15:22] koudai |
||
---|---|---|---|
Line 2: | Line 2: | ||
* 実際にMPIを用いたノード内およびノード間の並列計算を行います | * 実際にMPIを用いたノード内およびノード間の並列計算を行います | ||
- | * 事前にOpenMPIやMPICH2などのMPIライブラリを管理ノードにインストールしてください | + | * 事前にOpenMPI, MPICH2, Intel MPIなどのMPIライブラリを管理ノードにインストールしてください |
- | * 例えばOpenMPIであれば次のようにインストールできます< | + | * OpenMPIの場合、次のようにaptで簡単にインストールできるので、特にこだわりがなければお勧めです< |
$ sudo apt install openmpi-bin libopenmpi-dev | $ sudo apt install openmpi-bin libopenmpi-dev | ||
</ | </ | ||
+ | * **複数のMPIを一つのコンピュータに入れると、競合を起こしてMPIが動かなくなります** | ||
====== 準備 ====== | ====== 準備 ====== | ||
Line 107: | Line 107: | ||
$ mpiicc -o hello hello.c | $ mpiicc -o hello hello.c | ||
</ | </ | ||
- | * 管理ノード(4スレッド)で走らせてみます< | + | * 試しに管理ノードで走らせてみます< |
- | $ mpirun -n 4 hello | + | $ mpirun -n 4 ./hello |
Hello World! I am 0 of 4 from kanri. | Hello World! I am 0 of 4 from kanri. | ||
Hello World! I am 1 of 4 from kanri. | Hello World! I am 1 of 4 from kanri. | ||
Line 117: | Line 117: | ||
- | ===== ノード内並列 ===== | + | ===== ノード内並列計算 |
指定した計算ノードにジョブを投げてみます。 | 指定した計算ノードにジョブを投げてみます。 | ||
- | * MPIで指定のホストに投げる場合は、mpirunコマンドの最後にホスト名を入力します | + | * MPIで指定のホストに投げる場合は、オプション< |
- | * 計算ノードkeisan11にジョブを投げる場合は次のようにします< | + | * 計算ノードのkeisan11にジョブを投げる場合は次のようにします< |
- | $ mpirun -n 24 hello keisan11 | + | $ mpirun -n 24 --host |
Hello World! I am 0 of 24 from keisan11. | Hello World! I am 0 of 24 from keisan11. | ||
Hello World! I am 1 of 24 from keisan11. | Hello World! I am 1 of 24 from keisan11. | ||
Line 130: | Line 130: | ||
(以下略) | (以下略) | ||
</ | </ | ||
+ | |||
+ | |||
+ | ===== ノード間並列計算 ===== | ||
+ | |||
+ | ==== 通常の使い方 ==== | ||
+ | |||
+ | 複数の計算ノードにわたるジョブを投げてみます。 | ||
+ | |||
+ | * オプション< | ||
+ | * 計算ノードkeisan11, | ||
+ | $ mpirun -n 72 -hosts keisan11, | ||
+ | Hello World! I am 0 of 72 from keisan11. | ||
+ | Hello World! I am 1 of 72 from keisan12. | ||
+ | Hello World! I am 2 of 72 from keisan13. | ||
+ | Hello World! I am 3 of 72 from keisan11. | ||
+ | Hello World! I am 4 of 72 from keisan12. | ||
+ | Hello World! I am 5 of 72 from keisan13. | ||
+ | (以下略) | ||
+ | </ | ||
+ | |||
+ | ==== ホストファイルによるジョブの投入 ==== | ||
+ | |||
+ | 例えば計算ノードによって性能に差がある場合など、ノードごとのプロセス数を自分で管理したい場合はホストファイルを作成します。 | ||
+ | |||
+ | * MPICH, Intel MPIの場合 | ||
+ | <file - my_hosts> | ||
+ | keisan11:2 | ||
+ | keisan12:3 | ||
+ | </ | ||
+ | * OpenMPIの場合 | ||
+ | <file - my_hosts> | ||
+ | keisan11 slots=2 | ||
+ | keisan12 slots=3 | ||
+ | </ | ||
+ | |||
+ | 次のように実行します | ||
+ | < | ||
+ | $ mpirun -n 6 -f my_hosts ./hello | ||
+ | Hello World! I am 0 of 6 from keisan11. | ||
+ | Hello World! I am 1 of 6 from keisan11. | ||
+ | Hello World! I am 2 of 6 from keisan12. | ||
+ | Hello World! I am 3 of 6 from keisan12. | ||
+ | Hello World! I am 4 of 6 from keisan12. | ||
+ | Hello World! I am 5 of 6 from keisan11. | ||
+ | </ | ||
+ | * プロセスは keisan11 -> keisan11 -> keisan12 -> keisan12 -> keisan12 -> keisan11 -> keisan11 -> keisan12 -> keisan12 -> keisan12 -> keisan11 -> ... の順に割り振られて行きます | ||
+ | * Intel MPIの場合は< | ||
====== 参考 ====== | ====== 参考 ====== |