现在我正在使用exec将stderr重定向到错误日志
exec 2>> ${errorLog}
唯一的缺点是我必须以时间戳开始每次运行,因为exec只是将文本直接推送到日志文件中.有没有办法重定向stderr但允许我附加文本,如时间戳?
这很有趣.我问过一个非常了解bash的人,他告诉我这样:
foo() { while IFS='' read -r line; do echo "$(date) $line" >> file.txt; done; };
首先,它创建了一个从stdin读取一行原始输入的函数,而对IFS的赋值使它不会忽略空白.读完一行后,它会以前面的相应数据输出.然后你必须告诉bash将stderr重定向到该函数:
exec 2> >(foo)
你写入stderr的所有内容现在都将通过foo函数.请注意,当您在交互式shell中执行此操作时,您将不会再看到提示,因为它已打印到stderr,并且foo中的读取是行缓冲的:)