複数のインスタンスでスクリプトを実行するには? (Ubuntuサーバー)

複数のインスタンスでスクリプトを実行するには? (Ubuntuサーバー)

Ubuntuサーバーの複数のインスタンスでスクリプトを実行するには?

たとえば、10個の並列インスタンスで実行したいscanner.shPlacedという長期実行スクリプトがあります。/usr/bin/並列操作を開始する方法(そして他のフラグ/オプション/パラメータを渡す方法)は何ですか?

これらのインスタンスをどのように停止できますか?

答え1

GNU Parallelを使用すると、次のようになります。

parallel scanner {} ::: "--flags --for --instance 1" "--for 2" "--for 3"

CPUごとに1つのジョブを作成します。停止するにはCTRL-Cを押します。

GNU Parallelは、同じコンピュータまたはSSHを介してアクセスできる複数のコンピュータでタスクを並列に簡単に実行できる汎用の並列ハンドラです。多くの場合for、ループを置き換えることができます。

4つのCPUで32の異なるジョブを実行する場合は、並列化する簡単な方法は、各CPUで8つのジョブを実行することです。

簡単なスケジューリング

代わりに、GNU Parallel はタスクが完了すると新しいプロセスを作成し、CPU をアクティブに保つことで時間を節約します。

GNU並列スケジューリング

インストールする

ディストリビューションにGNU Parallelがパッケージされていない場合は、rootアクセスなしでプライベートインストールを実行できます。これは10秒で完了できます。

$ (wget -O - pi.dk/3 || lynx -source pi.dk/3 || curl pi.dk/3/ || \
   fetch -o - http://pi.dk/3 ) > install.sh
$ sha1sum install.sh | grep 883c667e01eed62f975ad28b6d50e22a
12345678 883c667e 01eed62f 975ad28b 6d50e22a
$ md5sum install.sh | grep cc21b4c943fd03e93ae1ae49e28573c0
cc21b4c9 43fd03e9 3ae1ae49 e28573c0
$ sha512sum install.sh | grep da012ec113b49a54e705f86d51e784ebced224fdf
79945d9d 250b42a4 2067bb00 99da012e c113b49a 54e705f8 6d51e784 ebced224
fdff3f52 ca588d64 e75f6033 61bd543f d631f592 2f87ceb2 ab034149 6df84a35
$ bash install.sh

その他のインストールオプションについては、以下を参照してください。http://git.savannah.gnu.org/cgit/parallel.git/tree/README

詳細

より多くの例を見る:http://www.gnu.org/software/parallel/man.html

紹介ビデオを見る:https://www.youtube.com/playlist?list=PL284C9FF2488BC6D1

このチュートリアルを見てください。http://www.gnu.org/software/parallel/parallel_tutorial.html

サポートを受けるには、メールリストに参加してください。https://lists.gnu.org/mailman/listinfo/parallel

答え2

#**parallel_scaller.sh**
# Script to async run scanner.sh
# USAGE: $> bash parallel_scanner.sh "FLAGS FOR INSTANCE 1" ... "FLAGS FOR INSTANCES 10"
$1=`echo $1 | sed 's/"//g'`
$2=`echo $1 | sed 's/"//g'`
$3=`echo $1 | sed 's/"//g'`
$4=`echo $1 | sed 's/"//g'`
$5=`echo $1 | sed 's/"//g'`
$6=`echo $1 | sed 's/"//g'`
$7=`echo $1 | sed 's/"//g'`
$8=`echo $1 | sed 's/"//g'`
$9=`echo $1 | sed 's/"//g'`
$10=`echo $1 | sed 's/"//g'`

bash scanner& $1 2>&1
bash scanner& $2 2>&1
bash scanner& $3 2>&1
bash scanner& $4 2>&1 
bash scanner& $5 2>&1
bash scanner& $6 2>&1
bash scanner& $7 2>&1
bash scanner& $8 2>&1
bash scanner& $9 2>&1
bash scanner& $10 2>&1

タスクをバックグラウンドに残します。 2>&1 は STDERR(2) を STDOUT(1) にリダイレクトします。

プロセスを終了するには、次のように入力します。

$> ps aux | grep scanner
$> kill $PIDS

答え3

Ansibleのような構成管理システムを試してみることをお勧めします。

Pythonで書かれており、初心者でも誰でも簡単に使用できます。

文書に従ってくださいhttp://docs.ansible.com/そして始めましょう!

答え4

提案された答えに加えて、次のコマンドを使用します。

nohup ./scanner.py -flag1 flag1value -flag2 flag2value &

新しいインスタンスを作成します。scanner.py私が使用しているすべての実行中のインスタンスを表示するには、次の手順を実行します。

ps aux | grep scanner.py

特定のインスタンスを終了するには、次のようにします。

kill -9 {PID}

コマンドから取得した{PID}場所は次のとおりです。ps auxkill -9 1234

関連情報