./sh >/dev/null 2>&1
>aaa 默认下等同于1>aaa 即指标准重定向输出到文件aaa而不输出在屏幕上(一般情况下)
./sh >/dev/null 2>&1即./sh 1>/dev/null 2>&1
./sh是任意shell 该脚本的标准输出(1)到/dev/null
标准错误输出(2)到&1 其中的&表示“等同于”
表示标准错误输出(2)重定向到的地方 = 标准输出(1)重定向的地方
此处标准输出的重定向位置是/dev/null 因为此前 (1)>/dev/null
至于/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 了。
===========================================
所以标准输出(1)和标准错误输出(2)输出的东西都没有
什么都不会显示出来
再有
./sh 2>&1 1>/dev/null
这时2先重定向到1重定向的位置 即屏幕
1输出到无底洞
所以该脚本的标准错误输出(2)被显示 而标准输出不显示(1)