我正在使用xargs在一组输入参数上执行命令,如下所示:
cat <someinput> | xargs -n 1 -P 5 <somecmd>
输入文件确实很长,需要很长时间才能运行。因此,我只是在等待命令提示符出现。有没有一种方法可以显示已完成的输入参数数量的进度条?
我尝试使用“酒吧”,但我总是得到“无限”的吞吐量。似乎xargs在执行命令之前会读取整个输入。
我正在使用xargs在一组输入参数上执行命令,如下所示:
cat <someinput> | xargs -n 1 -P 5 <somecmd>
输入文件确实很长,需要很长时间才能运行。因此,我只是在等待命令提示符出现。有没有一种方法可以显示已完成的输入参数数量的进度条?
我尝试使用“酒吧”,但我总是得到“无限”的吞吐量。似乎xargs在执行命令之前会读取整个输入。
Answers:
如果您具有GNU Parallel,则可以运行:
cat <someinput> | parallel --bar -P 5 <somecmd>
GNU Parallel是一个通用的并行器,使在ssh可以访问的同一台计算机或多台计算机上并行运行作业变得容易。
如果要在4个CPU上运行32个不同的作业,并行化的直接方法是在每个CPU上运行8个作业:
GNU Parallel会在完成时生成一个新进程-使CPU保持活动状态,从而节省时间:
安装
个人安装不需要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