linux命令无法重定向 linux 重定向错误输出( 二 )


再解释 21 file。这里也分两个过程:先将fd=2复制于fd=1 , 而此时fd=1重定向的文件是默认的/dev/stdout,所以fd=2也重定向到/dev/stdout;之后再将fd=1重定向到file文件上 。也就是说,这里的标准错误和标准输出仍然是分开输出的,只不过是使用/dev/stdout替代了/dev/stderr,使用file替代了/dev/stdout 。所以,最终的结果是标准错误输出到/dev/stdout,即屏幕上,而标准输出将输出到file文件中 。
可以使用下面的命令来测试 21 file。第一个ls命令是正确的,结果输出到/tmp/fff.log中,第二个ls命令是错误的,结果将直接输出到屏幕上 。
最后需要说明的是一种特殊情况 , 如果是 [word]  , 且word不是一个数值,比如 echo haha /tmp/fff.log ,那么 word 和 word 是等价的,都表示 word 21 ,即标准错误和标准输出都重定向同一个目标 。参考man bash的”Redirecting Standard Output and Standard Error”段落 。
如果在命令中直接改变重定向的位置,那么命令执行结束的时候描述符会自动还原 。正如上面的ls /boot 21 /tmp/fff.log命令,在ls执行结束后 , fd=2还原回默认的/dev/stderr , fd=1还原回默认的/dev/stdout 。
但是我们可以通过exec程序直接在当前的shell环境下改变重定向目标,只有在当前shell退出的时候才会释放描述符的绑定 。
Tips :shell的内建命令exec将并不启动新的shell,而是用要被执行命令替换当前的shell进程 , 并且将老进程的环境清理掉,而且exec命令后的其它命令将不再执行 。
不过,要注意一个例外,当exec命令来对文件描述符操作的时候,就不会替换shell , 而且操作完成后,还会继续执行接下来的命令 。
例如:下面的命令将标准错误fd=2指向fd=3对应的文件上 。
因此,我们可能在一段程序执行结束后,需要将描述符还原到原来的位置,并关闭不再需要的描述符 。毕竟描述符也是资源,是有限的(ulimit -n) 。
[n] filename :打开filename,并指定其文件描述符为n,该描述符是可读、可写的描述符 。若不指定n则默认为0 , 若filename文件不存在,则先创建filename文件 。
文件描述符的移动表示将文件描述符1移动到描述符2上,同时关闭文件描述符1 。
[n]digit- :将文件描述符digit代表的输出文件移动到n上,并关闭digit值的描述符 。
[n]digit- :将文件描述符digit代表的输入文件移动到n上,并关闭digit值的描述符 。
linux命令无法重定向的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux 重定向错误输出、linux命令无法重定向的信息别忘了在本站进行查找喔 。

推荐阅读