vieyahn2017 / shellv

shell command test and study
4 stars 1 forks source link

4.29 shell脚本中>/dev/null的含义 #31

Closed vieyahn2017 closed 5 years ago

vieyahn2017 commented 5 years ago

shell脚本中>/dev/null的含义

vieyahn2017 commented 5 years ago

shell脚本中>/dev/null的含义

在Linux/Unix中,一般在屏幕上面看到的信息是从stdout (standard output) 或者 stderr (standard error output) 来的。许多人会问,output 就是 output,送到屏幕上不就得了,为什麼还要分成stdout 和 stderr 呢?那是因为通常在 server 的工作环境下,几乎所有的程序都是 run 在 background 的,所以呢,为了方便 debug,一般在设计程序时,就把 stdout 送到/存到一个档案,把错误的信息 stderr 存到不同的档案。 哪些是正常的output呢,例如程序开始运行的时间,现在正在上线人数等等。 哪些是错误的output呢,例如无法找到使用者想要去的URL,或者信用卡认证失败等等。

有了上面这些认知后,回头来讲什麼是 > /dev/null 这是把 stdout 送到 /dev/null 里面 那什麼是 /dev/null 呢,/dev/null 是 Unix/Linux 里的【无底洞】 任何的 output 送去了【无底洞】就再也没了。相信我,真的没了! 那麼有人问,在什麼情况下要把 output 送去这无底洞呢? 这里没有标准答案, 不过一般呢,要是你不想看到 output 或者output 太多太大了,有可能把硬碟给挤爆了的时候,程序的设计就会考虑把 output 送到 /dev/null 了。

vieyahn2017 commented 5 years ago

Shell中>/dev/null 2>&1 详解

2018年03月09日 15:31:06 老杰_猎豹 阅读数:3868

hell中可能经常能看到:>/dev/null 2>&1

命令的结果可以通过%>的形式来定义输出

分解这个组合:“>/dev/null 2>&1” 为五部分。

1:> 代表重定向到哪里,例如:echo "123" > /home/123.txt 2:/dev/null 代表空设备文件 3:2> 表示stderr标准错误 4:& 表示等同于的意思,2>&1,表示2的输出重定向等同于1 5:1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于 "1>/dev/null"

因此,>/dev/null 2>&1 也可以写成“1> /dev/null 2> &1”

那么本文标题的语句执行过程为: 1>/dev/null :首先表示标准输出重定向到空设备文件,也就是不输出任何信息到终端,说白了就是不显示任何信息。 2>&1 :接着,标准错误输出重定向 到 标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件。

最常用的方式有:

command > file 2>file 与command > file 2>&1

它们有什么不同的地方吗?

首先command > file 2>file 的意思是将命令所产生的标准输出信息,和错误的输出信息送到file 中.command > file 2>file 这样的写法,stdout和stderr都直接送到file中, file会被打开两次,这样stdout和stderr会互相覆盖,这样写相当使用了FD1和FD2两个同时去抢占file 的管道。

而command >file 2>&1 这条命令就将stdout直接送向file, stderr 继承了FD1管道后,再被送往file,此时,file 只被打开了一次,也只使用了一个管道FD1,它包括了stdout和stderr的内容。 从IO效率上,前一条命令的效率要比后面一条的命令效率要低,所以在编写shell脚本的时候,较多的时候我们会command > file 2>&1 这样的写法。

vieyahn2017 commented 5 years ago

Linux中的标准输入输出

标准输入0    从键盘获得输入 /proc/self/fd/0  标准输出1    输出到屏幕(即控制台) /proc/self/fd/1  错误输出2    输出到屏幕(即控制台) /proc/self/fd/2 

/dev/null代表linux的空设备文件,所有往这个文件里面写入的内容都会丢失,俗称“黑洞” 

1、2>/dev/null意思就是把错误输出到“黑洞” 

2、>/dev/null 2>&1默认情况是1,也就是等同于1>/dev/null 2>&1。意思就是把标准输出重定向到“黑洞”,还把错误输出2重定向到标准输出1,也就是标准输出和错误输出都进了“黑洞” 

3、2>&1 >/dev/null意思就是把错误输出2重定向到标准出书1,也就是屏幕,标准输出进了“黑洞”,也就是标准输出进了黑洞,错误输出打印到屏幕  关于这里”&”的作用,我们可以这么理解2>/dev/null重定向到文件,那么2>&1,这里如果去掉了&就是把错误输出给了文件1了,用了&是表明1是标准输出。

vieyahn2017 commented 5 years ago

/dev/null 表示空设备,这里就是把日志记录到空设备里,就是不记录日志