0

我正在运行一个带有多个同时命令(python 脚本)的 bash 脚本。如果其中一个进程失败,我会尝试杀死所有进程。问题是 python 脚本仍在后台运行,如果其中一个失败,我的 bash 脚本不知道。

这是我的脚本中的一个片段:

set -a
trap cleanup_children SIGTERM
MY_PID=$$

function thread_listener () {
    to_execute="$1"
    echo "Executing $to_execute ..."
    $to_execute &
    PID=$!
    trap 'echo killing $PID; kill $PID' SIGTERM
    echo "Waiting for $PID ($to_execute) ..."
    wait $PID || if `kill -0 $MY_PID &> /dev/null`; then kill $MY_PID; fi
}

function cleanup_children () {
    for job in `jobs -p`
    do
        if `kill -0 $job &> /dev/null`; then
            echo "Killing child number $job"
            ps -p $job
            kill $job
        fi
    done
}

function create_app1 () {
    cd ${GIT_DIR}
    python ./create-app.py -myapp
    exit_code=$?
    echo "Create app1 ISO result: ${exit_code}"
    [ "${exit_code}" == "1" ] && exit 1
    mv ${ISO_OUTPUT_DIR}/rhel-7.1.iso ${ISO_OUTPUT_DIR}/${ISO_NAME}.iso
}

function create_app2 () {
    cd ${GIT_DIR}
    python ./create-app.py -do-something
    exit_code=$?
    echo "Create app1 ISO result: ${exit_code}"
    [ "${exit_code}" == "1" ] && exit 1
    mv ${ISO_OUTPUT_DIR}/rhel-7.1.iso ${ISO_OUTPUT_DIR}/${ISO_NAME}.iso
}

export -f create_app1
export -f create_app2

echo "MY_PID=$MY_PID"
thread_listener create_app1 &
PID_APP1=$!

thread_listener create_app2 &
PID_APP2=$!
wait

kill $PID_APP1 2> /dev/null
kill $PID_APP2 2> /dev/null
4

1 回答 1

0

嗯,这看起来很先进;)。我是否正确假设您永远不会看到“创建 app1 ISO 结果”输出,因为 python 脚本没有终止?信号未正确分派到 bash 后台作业可能是个问题。它也可能与您的 python 代码对信号没有正确反应有关。你检查过https://docs.python.org/2/library/signal.html吗?当然,您必须弄清楚如何在执行时中断 python 代码的确切步骤。我建议首先确保 python 代码以你想要的方式对信号作出反应。

于 2016-07-17T18:49:58.340 回答