首页 > 代码库 > 理解 Linux shell 中的一个方言:2>&1

理解 Linux shell 中的一个方言:2>&1

理解 Linux shell 中的一个方言:2>&1

前言

在使用 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 -> 1stderr -> 2

  • command > output 是 command 1> output 的简写

  • &文件描述符 是引用某个文件描述符的值

  • 2>&1 是错误输出的位置与标准输出的位置相同

理解 Linux shell 中的一个方言:2>&1