在bash中进行并行处理?

前端之家收集整理的这篇文章主要介绍了在bash中进行并行处理?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有数以千计的png文件,我喜欢用pngcrush做较小的。我有一个简单的找到.. -exec工作,但它是顺序的。我的机器有相当的资源,我会并行地做到这一点。

每个png执行的操作是:

pngcrush input output && mv output input

理想情况下,我可以指定并行操作的最大数量

有没有办法用bash和/或其他shell帮助程序?我是Ubuntu或Debian。

您可以使用xargs并行运行多个进程:
find /path -print0 | xargs -0 -n 1 -P <nr_procs> sh -c 'pngcrush $1 temp.$$ && mv temp.$$ $1' sh

xargs将读取find(由0个字符(-0)分隔)生成文件列表,并一次运行一个参数(-n 1)提供的命令(sh -c’…’sh)。 xargs将运行< nr_procs> (-P&l​​t; nr_procs>)。

原文链接:https://www.f2er.com/bash/388500.html

猜你在找的Bash相关文章