我想并行运行一些进程,我想做一个例子:
php scan.php 1.pdf > 1.txt & php scan.php 2.pdf > 2.txt & php scan.php 3.pdf > 3.txt
但问题是在目录中列出文件(如 1.pdf、2.pdf...)时自动调用它。
如果我用
find inprogress-gp/ -type f -name '*.pdf' -exec basename {} \; | xargs -n1 php scan.php
然后我可以打电话
php scan.php 1.pdf
php scan.php 2.pdf
php scan.php 3.pdf
....
知道如何解决这个任务吗?
最佳答案
如果您对 GNU Parallel 答案持开放态度:
parallel 'php scan.php {} > {.}.txt' ::: *.pdf
或者,如果您的 PDF 文件位于子目录中:
find . -name \*.pdf | parallel 'php {} > {.}.txt'
以下演示作业会在有可用作业槽的情况下立即启动,因此,仅使用 2 个内核,它会执行 10 秒 sleep 和 5 次每次 2 秒的进一步 sleep ,全部在 10 秒内完成:
parallel --line-buffer -j 2 'echo Job {#} starting; sleep {}; echo Job {#} done' ::: 10 2 2 2 2 2
Job 1 starting
Job 2 starting
Job 2 done
Job 3 starting
Job 3 done
Job 4 starting
Job 4 done
Job 5 starting
Job 5 done
Job 6 starting
Job 1 done
Job 6 done
关于linux - 在 Ubuntu 上并行化进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36308718/