2

我正在创建一个 bash 脚本来无损压缩 jpeg 和 png 文件,因此我在 Ubuntu 下使用了两个名为jpegoptimoptipng的包。A 将使用带有2 或 4 个核心处理器的脚本。我想使用我的 CPU 的全部容量。

问题是optipng默认不支持多线程(它只使用一个 CPU 内核),所以我决定启动2 或 4 个并行进程来更快地压缩图像。我已经将图像文件排序为 4 个几乎相等的数组(基于像素数),现在我需要并行运行这些进程。

我正在尝试将进程与&命令末尾的字符并行化,但它不能并行完成工作。

optipngout=$(optipng -$pnglevel -dir $outdir ${threaddata_1[@]} &)
optipngout=$(optipng -$pnglevel -dir $outdir ${threaddata_2[@]} &)
optipngout=$(optipng -$pnglevel -dir $outdir ${threaddata_3[@]} &)
optipngout=$(optipng -$pnglevel -dir $outdir ${threaddata_4[@]} &)

我必须捕捉命令的输出,所以我认为问题出在 $() 结构上。

4

2 回答 2

3

看看Gnu 并行。它使您只需对现有脚本进行少量修改即可做您想做的事情。

于 2013-03-22T10:08:34.667 回答
2

taskset我用and&命令解决了我的问题。感谢@jedwards

最终代码如下所示:

outstr=$(taskset 0xFFFFFFFF optipng -$pnglevel -dir $outdir ${threaddata_1[@]}) &
outstr=$(taskset 0xFFFFFFFF optipng -$pnglevel -dir $outdir ${threaddata_2[@]}) &
outstr=$(taskset 0xFFFFFFFF optipng -$pnglevel -dir $outdir ${threaddata_3[@]}) &
outstr=$(taskset 0xFFFFFFFF optipng -$pnglevel -dir $outdir ${threaddata_4[@]}) &
于 2013-03-22T12:00:17.563 回答