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

时间:2022-05-07
本文章向大家介绍理解 Linux shell 中的一个方言:2>&1,主要内容包括前言、I/O重定向、文件描述符、综合、小结、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。

前言

在使用 linux 命令或者 shell 编程时,这个用法常会遇到 2>&1

如果是刚开始接触Linux,这个东西的确不好理解,因为他没有直观的含义,不像一个命令,例如 cpcopy 的简写,很好记。

我以前刚用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 > outputcommand 1> output 的简写
  • &文件描述符 是引用某个文件描述符的值
  • 2>&1 是错误输出的位置与标准输出的位置相同