gpt4 book ai didi

linux - 在 Ubuntu 上并行化进程

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:25:12 24 4
gpt4 key购买 nike

我想并行运行一些进程,我想做一个例子:

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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com