linux – 在shell中运行一个进程池

前端之家收集整理的这篇文章主要介绍了linux – 在shell中运行一个进程池前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在寻找一种简单的方法,可以使用一个命令同时运行N个选定的进程.当我用ctrl c退出时,它应该将所有输出放在我的终端上并关闭所有输出.有没有现有的应用程序这样做?

我正在考虑像exec_many 10 foo这样的东西 – 它应该保持10个foos运行并重生任何死亡.

解决方法

我不知道有一个副手,但你可以用 Bash做这个而不需要太多的工作.我会将每个foo进程放在一个进程组中.然后,您可以在父级中捕获SIGINT并使用kill -pgid(进程组编号前的否定)终止进程组.您也可以将它们作为作业启动.所以他们都马上跑了(很多).最后,你可以每隔x秒循环一次作业输出(在循环中休眠)并获得计数,如果计数小于foo进程的数量,则可以激活另一个(可以通过制作得到更多的幻想)确定没有停止等).

粗略的版本可能是这样的:

#!/bin/bash

command=$1
n_job=$2

function kill_jobs {
    echo traped
    for job in $(jobs -p); do
        echo killing $job
        kill $job
    done
} 

trap 'kill_jobs; exit' SIGINT

while true; do
    current_jobs=$(jobs -pr)
    x=0;
    for job in $current_jobs; do
        (( x++ ))
    done;

    jobs_to_run=$(($n_job - $x))

    for (( y = 0; y < $jobs_to_run; y++ )); do
        $command &
    done
    x=0 
    sleep 5
done

你也可以在Pythton for Unix和Linux System Adminsitration的“Proccesses and Concurrency”部分找到类似的东西.

猜你在找的Linux相关文章