ожидаю дочерний процесс, но получаю ошибку: 'pid не является дочерним по отношению к этой оболочке'

Я пишу сценарий для параллельного получения данных из HDFS , затем я жду эти дочерние процессы в цикле for, но иногда он возвращает «pid не является дочерним по отношению к этой оболочке». иногда это работает хорошо… Это так озадачивает. Я использую "jobs -l", чтобы показать, что все задания выполняются в фоновом режиме. Я уверен, что этот pid является дочерним процессом процесса оболочки, и я использую «ps aux», чтобы убедиться, что эти pid назначены другому процессу. Вот мой сценарий.

PID=()
FILE=()
let serial=0

while read index_tar
do
        echo $index_tar | grep index > /dev/null 2>&1

        if [[ $? -ne 0 ]]
        then
                continue
        fi

        suffix=`printf '%03d' $serial`
        mkdir input/output_$suffix
        $HADOOP_HOME/bin/hadoop fs -cat $index_tar | tar zxf - -C input/output_$suffix \
                && mv input/output_$suffix/index_* input/output_$suffix/index &

        PID[$serial]=$!
        FILE[$serial]=$index_tar

        let serial++

done < file.list

for((i=0;i<$serial;i++))
do
        wait ${PID[$i]}

        if [[ $? -ne 0 ]]
        then
                LOG "get ${FILE[$i]} failed, PID:${PID[$i]}"
                exit -1
        else
                LOG "get ${FILE[$i]} success, PID:${PID[$i]}"
        fi
done
17
задан henshao 8 November 2011 в 10:04
поделиться