From f0951d09f0ae466cf7e6c828b1fd2545a658f2bc Mon Sep 17 00:00:00 2001 From: ligc Date: Sun, 1 Apr 2012 02:16:18 +0000 Subject: [PATCH] fix for bug 3487614: change to /xcatpost/mypostscript and add timestamp when running postscripts git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/branches/2.7@12081 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd --- xCAT/postscripts/xcatdsklspost | 91 ++++++++++++++++++---------------- 1 file changed, 48 insertions(+), 43 deletions(-) diff --git a/xCAT/postscripts/xcatdsklspost b/xCAT/postscripts/xcatdsklspost index c3bf44515..caa32373f 100755 --- a/xCAT/postscripts/xcatdsklspost +++ b/xCAT/postscripts/xcatdsklspost @@ -24,9 +24,11 @@ update_VPD() } # Run updatevpd only when necessary -lsvpd | grep -i cpu 2>&1 1>/dev/null -if [ "$?" = "1" ]; then - update_VPD +if [ -f /usr/sbin/lsvpd ]; then + /usr/sbin/lsvpd | grep -i cpu 2>&1 1>/dev/null + if [ "$?" = "1" ]; then + update_VPD + fi fi download_postscripts() @@ -36,7 +38,9 @@ download_postscripts() return 1; fi - INSTALLDIR=`grep 'INSTALLDIR' /opt/xcat/xcatinfo |cut -d= -f2` + if [ -f /opt/xcat/xcatinfo ]; then + INSTALLDIR=`grep 'INSTALLDIR' /opt/xcat/xcatinfo |cut -d= -f2` + fi if [ -z "$INSTALLDIR" ]; then INSTALLDIR="/install" fi @@ -231,8 +235,8 @@ if [ -x /usr/bin/openssl ]; then export USEOPENSSLFORXCAT fi -/xcatpost/getpostscript.awk | sed -e 's/<[^>]*>//g'|egrep -v '^ *$'|sed -e 's/^ *//' > /tmp/mypostscript; -MYCONT=`grep MASTER /tmp/mypostscript` +/xcatpost/getpostscript.awk | sed -e 's/<[^>]*>//g'|egrep -v '^ *$'|sed -e 's/^ *//' > /xcatpost/mypostscript; +MYCONT=`grep MASTER /xcatpost/mypostscript` #echo "MYCONT=$MYCONT" #if getpostscript.awk fails, the postscript will fall into infinit loop #so one retry_number is added to avoid sunc a condition @@ -249,8 +253,8 @@ while [ -z "$MYCONT" ]; do SLI=$((10 + $SLI)) sleep $SLI - /xcatpost/getpostscript.awk | sed -e 's/<[^>]*>//g'|egrep -v '^ *$'|sed -e 's/^ *//' > /tmp/mypostscript; - MYCONT=`grep MASTER /tmp/mypostscript` + /xcatpost/getpostscript.awk | sed -e 's/<[^>]*>//g'|egrep -v '^ *$'|sed -e 's/^ *//' > /xcatpost/mypostscript; + MYCONT=`grep MASTER /xcatpost/mypostscript` if [ ! -z "$MYCONT" ]; then break; fi @@ -259,7 +263,7 @@ done #save the MASTER into the xcatinfo file for node deployment case, #for updatenode case, only save it when -M is specified if [ $NODE_DEPLOYMENT -eq 1 ] || [ "$MODE" = "4" ]; then - new_ms=`grep '^MASTER' /tmp/mypostscript |cut -d= -f2` + new_ms=`grep '^MASTER' /xcatpost/mypostscript |cut -d= -f2` fi if [ -n "$new_ms" ]; then if [ ! -f /opt/xcat/xcatinfo ]; then @@ -278,39 +282,39 @@ fi # when called by the updatenode command #modify the UPDATENODE flag to 1 if [ "$MODE" = "1" ] || [ "$MODE" = "2" ]; then - TMP=`sed -e 's/UPDATENODE=0/UPDATENODE=1/g' /tmp/mypostscript`; - echo "$TMP" > /tmp/mypostscript; + TMP=`sed -e 's/UPDATENODE=0/UPDATENODE=1/g' /xcatpost/mypostscript`; + echo "$TMP" > /xcatpost/mypostscript; fi if [ "$MODE" = "5" ]; then - TMP=`sed -e 's/UPDATENODE=0/UPDATENODE=1\nUPDATESECURITY=1\nexport UPDATESECURITY/g' /tmp/mypostscript`; - echo "$TMP" > /tmp/mypostscript; + TMP=`sed -e 's/UPDATENODE=0/UPDATENODE=1\nUPDATESECURITY=1\nexport UPDATESECURITY/g' /xcatpost/mypostscript`; + echo "$TMP" > /xcatpost/mypostscript; fi # postscript name is specified with the updatenode if [ "XX$POSTSCRIPTS" != "XX" ]; then #remove all the postbootscripts - TMP=`sed "/postbootscripts-start-here/,/postbootscripts-end-here/ d" /tmp/mypostscript` - echo "$TMP" > /tmp/mypostscript + TMP=`sed "/postbootscripts-start-here/,/postbootscripts-end-here/ d" /xcatpost/mypostscript` + echo "$TMP" > /xcatpost/mypostscript #remove all the postscripts - TMP=`sed "/postscripts-start-here/,/postscripts-end-here/ d" /tmp/mypostscript` - echo "$TMP" > /tmp/mypostscript - echo "# postscripts-start-here" >> /tmp/mypostscript + TMP=`sed "/postscripts-start-here/,/postscripts-end-here/ d" /xcatpost/mypostscript` + echo "$TMP" > /xcatpost/mypostscript + echo "# postscripts-start-here" >> /xcatpost/mypostscript #add requested postscripts in - echo "$POSTSCRIPTS" | tr "," "\n" >> /tmp/mypostscript - echo "# postscripts-end-here" >> /tmp/mypostscript + echo "$POSTSCRIPTS" | tr "," "\n" >> /xcatpost/mypostscript + echo "# postscripts-end-here" >> /xcatpost/mypostscript fi #ADDSITEYUM is set by post.rh and post.rh.iscsi for full installtion #if [[ "$ADDSITEYUM" = "1" ]]; then -# TMP=`sed "/postscripts-start-here/ a addsiteyum" /tmp/mypostscript` -# echo "$TMP" > /tmp/mypostscript +# TMP=`sed "/postscripts-start-here/ a addsiteyum" /xcatpost/mypostscript` +# echo "$TMP" > /xcatpost/mypostscript #fi -#MYCONT=`cat /tmp/mypostscript` +#MYCONT=`cat /xcatpost/mypostscript` #echo "$MYCONT" # use the run_ps subroutine to run the postscripts -TMP=`sed "/postscripts-start-here/,/postscripts-end-here/ s/\(.*\)/run_ps \1/;s/run_ps\s*#/#/;s/run_ps\s*$//" /tmp/mypostscript` +TMP=`sed "/postscripts-start-here/,/postscripts-end-here/ s/\(.*\)/run_ps \1/;s/run_ps\s*#/#/;s/run_ps\s*$//" /xcatpost/mypostscript` echo " # subroutine used to run postscripts run_ps () { @@ -319,43 +323,44 @@ run_ps () { logfile=\"/var/log/xcat/xcat.log\" if [ -f \$1 ]; then - echo \"Running postscript: \$@\" | tee -a \$logfile - ./\$@ 2>&1 1> /tmp/tmp4xcatlog - cat /tmp/tmp4xcatlog | tee -a \$logfile + echo \"\`date\` Running postscript: \$@\" | tee -a \$logfile + #./\$@ 2>&1 1> /tmp/tmp4xcatlog + #cat /tmp/tmp4xcatlog | tee -a \$logfile + ./\$@ 2>&1 | tee -a $logfile else - echo \"Postscript \$1 does NOT exist.\" | tee -a \$logfile + echo \"\`date\` Postscript \$1 does NOT exist.\" | tee -a \$logfile fi } # subroutine end -" > /tmp/mypostscript -echo "$TMP" >> /tmp/mypostscript -TMP=`sed "/postbootscripts-start-here/,/postbootscripts-end-here/ s/\(.*\)/run_ps \1/;s/run_ps\s*#/#/;s/run_ps\s*$//" /tmp/mypostscript` -echo "$TMP" > /tmp/mypostscript +" > /xcatpost/mypostscript +echo "$TMP" >> /xcatpost/mypostscript +TMP=`sed "/postbootscripts-start-here/,/postbootscripts-end-here/ s/\(.*\)/run_ps \1/;s/run_ps\s*#/#/;s/run_ps\s*$//" /xcatpost/mypostscript` +echo "$TMP" > /xcatpost/mypostscript if [ $NODE_DEPLOYMENT -eq 1 ] || [ "$MODE" = "4" ]; then #notify the server that we are done with netbooting - CNS=`grep NODESTATUS= /tmp/mypostscript |awk -F = '{print $2}'` + CNS=`grep NODESTATUS= /xcatpost/mypostscript |awk -F = '{print $2}'` if [ -z "$CNS" ] || [ "$CNS" != "'0'" -a "$CNS" != "'N'" -a "$CNS" != "'n'" ]; then - echo "updateflag.awk \$MASTER 3002 \"installstatus booted\"" >> /tmp/mypostscript + echo "updateflag.awk \$MASTER 3002 \"installstatus booted\"" >> /xcatpost/mypostscript fi fi -DHCP_TMP=`sed 's/\(DHCPINTERFACES=\)\(.*\)$/\1"\2"/' /tmp/mypostscript` -echo "$DHCP_TMP" > /tmp/mypostscript +DHCP_TMP=`sed 's/\(DHCPINTERFACES=\)\(.*\)$/\1"\2"/' /xcatpost/mypostscript` +echo "$DHCP_TMP" > /xcatpost/mypostscript -CLEANUPXCATPOST=`grep CLEANUPXCATPOST= /tmp/mypostscript |awk -F = '{print $2}'` +CLEANUPXCATPOST=`grep CLEANUPXCATPOST= /xcatpost/mypostscript |awk -F = '{print $2}'` if [ "$CLEANUPXCATPOST" = "'1'" ] || [ "$CLEANUPXCATPOST" = "'yes'" ]; then - echo "cd /" >> /tmp/mypostscript + echo "cd /" >> /xcatpost/mypostscript # /xcatpost might be read-only for statelite nodes - echo "rm -rf /xcatpost/*" >> /tmp/mypostscript + echo "rm -rf /xcatpost/*" >> /xcatpost/mypostscript fi -chmod +x /tmp/mypostscript -if [ -x /tmp/mypostscript ];then - /tmp/mypostscript +chmod +x /xcatpost/mypostscript +if [ -x /xcatpost/mypostscript ];then + /xcatpost/mypostscript fi -#rm -f /tmp/mypostscript +#rm -f /xcatpost/mypostscript #tell user it is done when this is called by updatenode command if [ "$MODE" = "1" ] || [ "$MODE" = "2" ] || [ "$MODE" = "5" ]; then