我有一个带有for循环的shell脚本。在迭代之前,循环是否等待在其体内执行命令?
先谢谢
这是我的代码。命令会顺序执行还是并行执行?
for m in "${mode[@]}"
do
cmd="exec $perlExecutablePath $perlScriptFilePath --owner $j -rel $i -m $m"
$cmd
eval "$cmd"
done
答案 0 :(得分:2)
假设您没有后台命令,那么是。
例如:
for i in {1..10}; do cmd; done
在继续循环之前等待cmd
完成,而:
for i in {1..10}; do cmd &; done
没有按'吨
如果你想并行运行你的命令,我建议你将你的循环改为:
for m in "${mode[@]}"
do
"$perlExecutablePath" "$perlScriptFilePath" --owner "$j" -rel "$i" -m "$m" &
done
这会在后台运行每个命令,因此在下一个命令启动之前它不会等待一个命令完成。
另一种方法是查看专为此目的而设的GNU Parallel。
答案 1 :(得分:0)
使用GNU Parallel看起来像这样:
parallel $perlExecutablePath $perlScriptFilePath --owner $j -rel $i -m {} ::: "${mode[@]}"
GNU Parallel是一个通用的并行程序,可以很容易地在同一台机器上或在你有ssh访问权限的多台机器上并行运行作业。它通常可以替换for
循环。
如果要在4个CPU上运行32个不同的作业,并行化的直接方法是在每个CPU上运行8个作业:
GNU Parallel会在完成后生成一个新进程 - 保持CPU处于活动状态,从而节省时间:
<强>安装强>
如果没有为您的发行版打包GNU Parallel,您可以进行个人安装,不需要root访问权限。这可以在10秒内完成:
(wget -O - pi.dk/3 || curl pi.dk/3/ || fetch -o - http://pi.dk/3) | bash
有关其他安装选项,请参阅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