如何在Bash中并行运行给定的函数?

前端之家收集整理的这篇文章主要介绍了如何在Bash中并行运行给定的函数?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
还有一些类似的问题,但是我的问题并不是“并行运行几个程序” – 这可以通过并行或xargs来完成。

我需要并行化Bash函数

让我们想象一下这样的代码

for i in "${list[@]}"
do
    for j in "${other[@]}"
    do
    # some processing in here - 20-30 lines of almost pure bash
    done
done

一些处理需要调用外部程序。

我想运行一些(4-10)任务,每个运行不同的$ i。 $ list中的元素总数为> 500。

我知道我可以把整个j …完成循环在外部脚本,并且只是并行调用这个程序,但是可以不分割两个单独程序之间的功能吗?

编辑:请考虑 Ole’s answer

而不是单独的脚本,您可以将代码放在单独的bash函数中。然后,您可以导出它,并通过xargs运行它:

#!/bin/bash
dowork() { 
    sleep $((RANDOM % 10 + 1))
    echo "Processing i=$1,j=$2"
}
export -f dowork

for i in "${list[@]}"
do
    for j in "${other[@]}"
    do
        printf "%s\0%s\0" "$i" "$j"
    done
done | xargs -0 -n 2 -P 4 bash -c 'dowork "$@"' --

猜你在找的Bash相关文章