シェルスクリプト内で実行されたコマンドとその結果をすべて出力してくれるのがbash
の-x
オプション。「わざわざロギングをコーディングするほどではないが、とはいえログが何もないのはなんとなく気が引ける」場合、あるいは「書いたシェルスクリプトをデバッグしたい」場合などにわたしはよく使います。
さてbash -x sample.sh
とターミナルに打ち込んだとして、__出力される情報をターミナルで目検するだけではなく、ログファイルなどに保存しておきたい__という場合にはどうすればよいでしょうか?
答えは簡単。__bash -x
が吐き出すデバッグ情報は実のところ標準エラー出力に出力されています。__よってそのデバッグ情報をファイルに保持したいという場合は、たとえば以下のようにして標準エラー出力を目的のファイルへリダイレクトしてやればよいということになります。
bash -x sample.sh &> sample.log
以上、ちょっとしたTIPSでした(´・ω・`)