シェルスクリプトログでスクリプトをデバッグする方法は? [コピー]

シェルスクリプトログでスクリプトをデバッグする方法は? [コピー]

デバッグモードに設定されたスクリプトがあります。

set -x
#!/bin/sh

ALLCIRCLS="/var/tmp/release/ALLCIRCLS.txt"
NONRBTIPS="/var/tmp/release/NONRBTIP.txt"
RBTIPS="/var/tmp/release/RBTIPS.txt"
NONRBTIPGNOCIP="/var/tmp/release/NONRBTIPGNOCIP.txt"
NONRBTROOTIP="/var/tmp/release/NONRBTROOTIP.txt"
LOGFILE="/var/tmp/release/log_result.log"
release="/var/tmp/deployment/*"

for IP_ADDRESS in $(cat $NONRBTIPS); do
   echo "TEST FOR ${IP_ADDRESS}" >> $LOGFILE
   scp -r /var/tmp/deployment/* test@${IP_ADDRESS}:/var/mnt/promptbase/prompts/local_cms >> $LOGFILE
   if [ $? -ne 0 ] ; then
      echo "Secure copy is failed " >> $LOGFILE
      exit 1
   else
      echo "Secure copy is successfull"
   fi
done

デバッグモードなので、私が得る出力は次のようになります。

+ ALLCIRCLS=/var/tmp/release/ALLCIRCLS.txt
+ NONRBTIPS=/var/tmp/release/NONRBTIP.txt
+ RBTIPS=/var/tmp/release/RBTIPS.txt
+ NONRBTIPGNOCIP=/var/tmp/release/NONRBTIPGNOCIP.txt
+ NONRBTROOTIP=/var/tmp/release/NONRBTROOTIP.txt
+ LOGFILE=/var/tmp/release/log_result.log
+ release='/var/tmp/deployment/*'
++ cat /var/tmp/release/NONRBTIP.txt
+ for IP_ADDRESS in '$(cat $NONRBTIPS)'
+ echo 'TEST FOR 172.19.117.198'
+ scp -r /var/tmp/deployment/ID_MB4_W2JUL19 [email protected]:/var/mnt/promptbase/prompts/local_cms

$LOGFILE端末をきれいに保ち、?を使用してスクリプトのすべてのデバッグ情報をログファイルに印刷したいと思います。

答え1

出力をlog.txtなどのファイルにリダイレクトできます。

スクリプト名がtest.shであるとします。

./test.sh > log.txt

関連情報