前端之家收集整理的这篇文章主要介绍了
在bash中将文本附加到stderr重定向,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
现在我使用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中读取是行缓冲的:)