在 shell 程式中,最常使用的 FD (file descriptor) 大概有三个, 分别是:
0 是一个文件描述符,表示标准输入(stdin)
1 是一个文件描述符,表示标准输出(stdout)
2 是一个文件描述符,表示标准错误(stderr)
在标准情况下, 这些FD分别跟如下设备关联:
stdin(0): keyboard 键盘输入,并返回在前端
stdout(1): monitor 正确返回值 输出到前端
stderr(2): monitor 错误返回值 输出到前端
举例说明吧:假如当前目录只有一个文件 1.txt
[root@xgmin]# ls
1.txt
[root@xgmin]# ls 1.txt 2.txt
ls: 2.txt: No such file or directory 返回错误值, 这就是2输出 ,1``.txt 而这个就是所谓的1输出
2.重定向解析
a.2>&1经常使用的这个2>&1,怎么理解呢?
对于2>&1的理解,2就是标准错误,1是标准输出,那么这条命令就是相当于把标准错误重定向 到标准输出。为什么是&1而不是1,这里& 符号可以理解为引用(reference)。&1 就是对标准输出的引用。
b.>&2 即 1>&2 也就是把结果输出到和标准错误一样;之前如果有定义标准错误重定向到某log文件,那么标准输出也重定向到这个log文件
如:ls 2>a1 >&2 (等同 ls >a1 2>&1)把标准输出和标准错误都重定向到a1,终端上看不到任何信息。
c.ls a.txt >a 2>a 和 ls a.txt >a 2>&1的区别
可以理解为执行ls a.txt产生的标准输入重定向到文件a中,标准错误也重定向到文件a中。
看起来ls a.txt >a 2>&1等价于ls a.txt 1>a 2>&1。在IO效率讲还是有区别的,区别就在于前者只打开一次文件a,后者会打开文件两次,并导致stdout被stderr覆盖。&1的含义就可以理解为用标准输出的引用,引用的就是重定向标准输出产生打开的a。从IO效率上来讲,command 1>a 2>&1比 command 1>a 2>a的效率更高。
3.bash之shell反弹
https://blog.csdn.net/Auuuuuuuu/article/details/89059176,这里写的很清楚。