在bash中将文本附加到stderr重定向
发布时间:2020-12-16 01:23:10 所属栏目:安全 来源:网络整理
导读:现在我使用exec将stderr重定向到一个错误日志 exec 2 ${errorLog} 唯一的缺点是我必须用一个时间戳开始每个运行,因为exec只是将文本直接推入日志文件.有没有办法重定向stderr,但允许我附加文本,如时间戳? 这很有趣我问过一个知道bash的人,他告诉我: foo()
现在我使用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中读取是行缓冲的:) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |