我写了一个脚本从平行的HDFS获取数据,然后我在for循环中等待这些子进程,但有时它返回“pid不是这个壳的孩子“。有时候,它运作良好。它很困惑。我使用“jobs -l”来显示所有在后台运行的作业。我确定这些pid是shell进程的子进程,我使用“ps aux”来确保这些pid是note分配给其他进程。这是我的脚本。等待子进程,但得到错误:'pid不是这个shell的孩子'
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
无论是我把这些循环在{...}块,也不使用....完成| somepipe。 – henshao
尽管如此,您仍然可以检查这一思路。在两个位置(并在脚本的顶级位置打印$ BASHPID,$$,$ BASH_SUBSHELL) – sehe