我正在尝试获取当前的stdout重定向,并遇到一些麻烦。
我有一个总是使用stdout重定向运行的脚本,即:
myscript.sh > /tmp/output.log
在myscript.sh中,我需要找出输出到的文件。
我正在尝试这个(不工作):
logfile=$(readlink -f /proc/self/fd/1)
例如,输出logfile = /tmp/sflq.r3f。我需要找到它会转到/tmp/output.log
这甚至可能吗?
如果重要的话,我正在使用korn shell ......
谢谢!
答案 0 :(得分:5)
$()
使用一个管道(或者对于ksh来说 - 一个临时文件,ksh似乎用它来模拟通常是其他shell中的管道)来捕获readlink的输出。
在$()
内,stdout就是那个管道(或者是ksh的临时文件)。
您可以使用以下内容来解决这个插入的stdout文件:
{ logfile=$(readlink -f /proc/self/fd/3); } 3>&1
# my ksh 93 needs the { ;} -- dash, and zsh don't
echo "The logfile is: $logfile"
现在:
./myscript.sh > /tmp/output.log
echo OUTPUT.LOG
cat /tmp/output.log
应该给你:
OUTPUT.LOG
The logfile is: /tmp/output.log
另一个选择是考虑一种完全避免变量的方法:
echo -n "The logfile is: "
readlink -f /proc/self/fd/1 #goes straight to stdout so no need to capture
答案 1 :(得分:0)
伙计们,你似乎非常关注/proc/*self*/fd
。在你的代码调用的上下文中考虑这个 self 究竟是什么意思,如果在脚本的主体中使用/proc/$$/fd
这样的东西不是一个更好的主意......
(提示:$(readlink …)
在子shell中执行。)