加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

在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中读取是行缓冲的:)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读