有没有可能将Bourne shell脚本的所有输出重定向到某个地方,但脚本本身包含shell命令?
重定向单个命令的输出很简单,但我想要更多这样的输出:
#!/bin/sh
if [ ! -t 0 ]; then
# redirect all of my output to a file here
fi
# rest of script...
含义:如果脚本以非交互方式运行(例如,cron),请将所有内容的输出保存到一个文件中。如果从shell以交互方式运行,让输出像往常一样转到stdout。
我想对通常由FreeBSD定期实用程序运行的脚本执行此操作。这是日常运行的一部分,我通常不关心每天在电子邮件中看到它,所以我没有发送它。但是,如果这个特定脚本中的某些内容失败了,这对我来说很重要,我希望能够捕获并通过电子邮件发送日常工作中这一部分的输出。
更新:Joshua的回答恰到好处,但我也想保存和恢复整个脚本周围的stdout和stderr,这是这样完成的:
# save stdout and stderr to file
# descriptors 3 and 4,
# then redirect them to "foo"
exec 3>&1 4>&2 >foo 2>&1
# ...
# restore stdout and stderr
exec 1>&3 2>&4
发布于 2008-11-24 16:29:53
通常我们会将其中一个放在脚本的顶部或靠近脚本的顶部。解析其命令行的脚本将在解析后执行重定向。
将stdout发送到文件
exec > file
使用stderr
exec > file
exec 2>&1
将stdout和stderr都追加到文件
exec >> file
exec 2>&1
作为Jonathan Leffler mentioned in his comment
exec
有两个独立的工作。第一种方法是用新程序替换当前正在执行的shell (脚本)。另一个是更改当前shell中的I/O重定向。这一点的区别在于没有exec
参数。
发布于 2008-11-24 16:44:55
您可以使整个脚本成为如下所示的函数:
main_function() {
do_things_here
}
然后,在脚本的末尾添加以下内容:
if [ -z $TERM ]; then
# if not run via terminal, log everything into a log file
main_function 2>&1 >> /var/log/my_uber_script.log
else
# run via terminal, only output to screen
main_function
fi
或者,您可以在每次运行时将所有内容都记录到日志文件中,然后通过简单的操作将其输出到stdout:
# log everything, but also output to stdout
main_function 2>&1 | tee -a /var/log/my_uber_script.log
发布于 2015-04-16 04:46:25
要保存原始stdout和stderr,您可以使用:
exec [fd number]<&1
exec [fd number]<&2
例如,以下代码将把"walla1“和"walla2”输出到日志文件(a.txt
),将"walla3“输出到stdout,将"walla4”输出到stderr。
#!/bin/bash
exec 5<&1
exec 6<&2
exec 1> ~/a.txt 2>&1
echo "walla1"
echo "walla2" >&2
echo "walla3" >&5
echo "walla4" >&6
https://stackoverflow.com/questions/314675
复制相似问题