From 77ea7d4e414056610aee95cc19c009f088a56334 Mon Sep 17 00:00:00 2001 From: xq2005 Date: Mon, 16 Sep 2013 01:50:23 -0700 Subject: [PATCH] bug 3776: post install script hung when deploy rhels5.9 --- xCAT/postscripts/xcatflowrequest | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/xCAT/postscripts/xcatflowrequest b/xCAT/postscripts/xcatflowrequest index ab1253ead..caa4b41cf 100755 --- a/xCAT/postscripts/xcatflowrequest +++ b/xCAT/postscripts/xcatflowrequest @@ -5,21 +5,22 @@ # It is called by xcatdsklspost before calling getpostscripts.awk # it is called by remoteshell before calling getcredentials.awk # -exec 13<>/dev/udp/$1/$2 -echo "resourcerequest: xcatd" >&13 +exec {REMOTEFD}<>/dev/udp/$1/$2 +echo "resourcerequest: xcatd" >&$REMOTEFD parpid=$$ touch /tmp/goahead.$parpid touch /tmp/killme.$parpid exec 2> /dev/null while ! grep 'resourcerequest: ok' /tmp/goahead.$parpid > /dev/null; do ( - echo "resourcerequest: xcatd" >&13 - exec 14<>/proc/self/stat - read mystat<&14 + echo "resourcerequest: xcatd" >&$REMOTEFD + exec {LOCALFD}<>/proc/self/stat + read mystat<&$LOCALFD mypid=$(echo $mystat|cut -d " " -f 4) (sleep $(((RANDOM%60)+120)).$((RANDOM%50)); if [ -f /tmp/killme.$parpid ]; then kill -TERM $mypid; fi) & echo $! > /tmp/sleeperpid.$parpid - exec awk '{print $0 > "/tmp/goahead.'$parpid'";exit}' <&13 + exec awk '{print $0 > "/tmp/goahead.'$parpid'";exit}' <&$REMOTEFD + exec {LOCALFD}>&- ) done sleeper=$(cat /tmp/sleeperpid.$parpid) @@ -27,4 +28,5 @@ sleeper=$(ps -ef|awk "\$3==$sleeper"|awk '{print $2}') rm /tmp/goahead.$parpid rm /tmp/sleeperpid.$parpid rm /tmp/killme.$parpid +exec {REMOTEFD}>&- kill -TERM $sleeper