我有一些关键的bash脚本,由我无法控制的代码调用,我无法看到他们的控制台输出.我想要完整地了解这些脚本的作用,以便以后分析.为此,我想让每个脚本都自我跟踪.这是我目前正在做的事情:
#!/bin/bash # if last arg is not '_worker_',relaunch with stdout and stderr # redirected to my log file... if [[ "$BASH_ARGV" != "_worker_" ]]; then $0 "$@" _worker_ >>/some_log_file 2>&1 # add tee if console output wanted exit $? fi # rest of script follows...
有更好,更清洁的方法吗?
#!/bin/bash exec >>log_file 2>&1 echo Hello world date
exec有关于重定向的神奇行为:“如果未指定命令,则任何重定向在当前shell中生效,返回状态为0.如果存在重定向错误,则返回状态为1.”
此外,关于您的原始解决方案,执行“$0”优于“$0”;退出$?,因为前者在子进程退出之前不会留下额外的shell进程.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。