理解 Linux shell 中的一个方言:2>&1
2016-11-14 杜亦舒
前言
在使用 linux 命令或者 shell 编程时,这个用法常会遇到 2>&1
如果是刚开始接触Linux,这个东西的确不好理解,因为他没有直观的含义,不像一个命令,例如 cp
是 copy
的简写,很好记。
我以前刚用Linux时就对这个东西迷糊了一段时间,今天刚好看到一篇文章介绍他,感觉很有必要总结出来,分享给还不是很理解这个方言的朋友。
下面看一个命令示例,然后分析下他是如何工作的:
ls foo > /dev/null 2>&1
首先需要了解两个基础概念:I/O重定向、文件描述符
I/O重定向
重定向 的作用是把一个命令的输出结果发送到另一个地方。
例如,使用 cat
命令查看一个文件,文件内容会被打印到屏幕 :
$ cat foo.txt
foo
bar
baz
此时,屏幕就是命令的标准输出( standard output 【stdout】)位置。
我们可以把文件内容发送到别的地方,例如,重定向到 output.txt
文件中 :
$ cat foo.txt > output.txt
$ cat output.txt
foo
bar
baz
其中第一个 cat
使用 >
把 stdout
的位置改为了另一个文件。
再看一个例子,查看一个不存在的文件:
$ cat nop.txt > output.txt
cat: nop.txt: No such file or directory
这里的错误提示信息为什么显示到了屏幕,而不是发送到 output.txt
呢?
这就涉及到了另一个位置:标准错误输出standard error 【stderr】
。
$ cat nop.txt > output.txt
这个命令是把 stdout
定位到了文件,而没有定义 stderr
的位置,所以错误信息显示到了默认的位置:屏幕。
文件描述符
Linux 中一切皆文件,每个文件都有一个文件描述符,值是个正整数。
所以,标准输出stdout
与 标准错误输出stderr
也有自己的文件描述符:
- stdout 为 1
- stderr 为 2
综合
$ cat foo.txt > output.txt
实际上就是这样的:
$ cat foo.txt 1> output.txt
就是把 stdout
指向了 output.txt
,>
是 1>
的简写。
所以重定向错误信息的输出就应该是这样的:
$ cat nop.txt 2> error.txt
$ cat error.txt
cat: nop.txt: No such file or directory
连个命令连起来就是:
$ cat foo.txt > output.txt 2> error.txt
同时重定向了标准输出stdout
与标准错误输出stderr
。
回顾开头的那个命令:
ls foo > /dev/null 2>&1
现在基本上已经可以理解了:
- stdout 重定向到
/dev/null
- stderr 重定向到
&1
/dev/null
是空设备的意思,重定向到空设备,也就是输出信息不要了。
&1
表示:文件描述符1 的值,也就是标准输出的值,那么 2>&1
就是 标准错误输出 与 标准输出 一样,也是重定向到空设备。
所以这个命令的意思是:正确信息和错误信息都不显示了。
小结
几个关键点:
- 两个输出:标准输出(stdout 正常信息)、标准错误输出(stderr 错误信息)
>
可以改变输出的位置- 文件描述符,
stdout -> 1
,stderr -> 2
command > output
是command 1> output
的简写&文件描述符
是引用某个文件描述符的值2>&1
是错误输出的位置与标准输出的位置相同