在bash中考虑我做了这个愚蠢的事情:
$exec 1>&- $exec 2>&-
我相信我还没有输掉比赛(哎呀其实我输了The Game)我可以重新连接到stdout.想到的是我不知道怎么做.
我尝试的第一件事是创建一个fifo并使用另一个shell来监视第一个shell的stdout.它不起作用,我不知道为什么:
在tty1
$mkfifo stdout $exec 1>stdout $echo "Hello stdout"
TTY2
$tail -f stdout $# nothing here
How can I reconnect my closed
STDOUT
andSTDERR
after all?
我知道解决方法是在玩之前保存STDOUT:
$exec 3>&1 $exec 1>&- $echo "Nothing will see this" $exec 1<&3 # Restoring stdout
我在Ubuntu机器上运行它,所以我不确定它是否适合你,但这就是我所做的:
$exec 1>&0 $exec 2>&0
突然,我重新连接了STDOUT和STDERR.魔法!
说明:运行以下命令,我们得到以下输出:
$ls -l /dev/stdout lrwxrwxrwx 1 root root 15 Jun 11 23:39 /dev/stdout -> /proc/self/fd/1 $ls -l /proc/self/fd/1 lrwx------ 1 jay jay 64 Jun 22 01:34 /proc/self/fd/1 -> /dev/pts/10 $ls -l /proc/self/fd/ total 0 lrwx------ 1 jay jay 64 Jun 22 01:35 0 -> /dev/pts/10 lrwx------ 1 jay jay 64 Jun 22 01:35 1 -> /dev/pts/10 lrwx------ 1 jay jay 64 Jun 22 01:35 2 -> /dev/pts/10 lr-x------ 1 jay jay 64 Jun 22 01:35 3 -> /proc/12224/fd
由于所有三个fd指向相同的东西,我们可以通过指向exec 1>& 0和exec 2>& 0执行的/ dev / pts / 10将它们恢复正常