created: 2022-02-23T08:02:39.000Z

bashで{標準,エラー}出力にタイムスタンプをつける

スクリプトの先頭でこんな感じで exec をしておけばよい。

function addtimestamp() {
    while IFS= read -r line; do
        printf '%s %s\n' "[$(date +"%Y-%m-%d %H:%M:%S")]" "$line";
    done
}
readonly scriptname=$(basename ${0%.sh})
exec 1> >(addtimestamp | tee -a "/tmp/$scriptname-stdout.log")
exec 2> >(addtimestamp | tee -a "/tmp/$scriptname-stderr.log")

参考