如何将shell脚本的全部执行结果记入一个log文件
先给大家介绍下将shell脚本的全部执行结果记入一个log文件
./script.sh >>logfile 2>&1
执行脚本script.sh时将错误输出2以及标准输出1都一起以附加写方式导入logfile文件。
即使多次执行脚本,之前的log也仍然存在。
Shell基础执行脚本并输出日志文件
shell 错误输出重定向到标准输出
./tmp/test.sh > /tmp/test.log 2>&1
>和<是文件重定向符。那么1和2是什么?
shell中每个进程都和三个系统文件相关联
标准输入stdin
标准输出stdout
标准错误stderr
三个系统文件的文件描述符分别为0,1和2。
所以这里2>&1的意思就是将标准错误也输出到标准输出当中。
下面通过一个例子来展示2>&1有什么作用:
$ cat test.sh
t
date
test.sh中包含两个命令,其中t是一个不存在的命令,执行会报错,默认情况下,错误会输出到stderr。date则能正确执行,并且输出时间信息,默认输出到stdout。
标准输出重定向到log文件中,标准错误打印在屏幕上
./test.sh > test1.log
/test.sh: line 1: t: command not found
$ cat test1.log
Tue Oct 9 20:51:50 CST 2007
可以看到,date的执行结果被重定向到log文件中了,而t无法执行的错误则只打印在屏幕上。标准输处和标准错误重定向到同一log文件中
$ ./test.sh > test2.log 2>&1
$ cat test2.log
./test.sh: line 1: t: command not found
Tue Oct 9 20:53:44 CST 2007
这次,stderr和stdout的内容都被重定向到log文件中了。
实际上, >就相当于1>也就是重定向标准输出,不包括标准错误。通过2>&1,就将标准错误重定向到标准输出了(stderr已作为stdout的副本),那么再使用>重定向就会将标准输出和标准错误信息一同重定向了。
标准输处和标准错误重定向 到此这篇关于如何将shell脚本的全部执行结果记入一个log文件的文章就介绍到这了,更多相关shell脚本log文件内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!sh mr_add_test.sh 1>log.log 2>log_err.log
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341