Linux中的2>&1使用学习


在linux脚本中,经常会看到有“command > file 2>&1”这种用法,一直不太理解,今天找时间查了相关资料,总结如下:

(1)1是标准输出stdout,2是标准出错stderr,>代表重定向;

(2)command > file,实际上是command 1>file,linux默认就是1,一般都省略了;

(3)2>&1,这个代表把stderr重定向到stdout,至于为什么会有个&,我的理解是如果2>1的话,系统无法区分1是代表stdout还是文件名,所以要用&1来标识是stdout;

“command > file 2>&1”整句命令用strace看的话,分别顺序调用了下面三个系统调用:

  1. open(file) == 3;  
  2. dup2(3,1);  
  3. dup2(1,2);  

此处dup2(3,1)将句柄1变成了3的duplicate。再dup2(1,2),将2冲变成1的duplicate。执行完之后2和1都会变成了3的duplicate,也就是2和1全部都重定向到打开的file。

补充几种用法

(1)还有一种用法:“command >& file”,这里的>&代表将所有的输出都定向到file;

(2)n<&-表示将 n 号输入关闭;

(3) n>&-表示将 n 号输出关闭;

相关内容