linux command>file 2>&1 & 命令详解
command>file 2>&1 &
命令的最后一个&表示把该命令以后台的job的形式运行
一个命令的执行伴随着三种输入输出
标准输入(stdin):默认指向键盘的输入,可以通过标准输入重定向<,让标准输入指向文件输入
标准输出(stdout) :指命令产生的正常的输出,如echo aaa,标准输出默认指向终端显示器,可以通过输出重定向>,让标准输出重定向到文件
标准错误输出(stderr):指命令产生的错误信息的输出,如执行了不存在的命令t,标准错误输出也默认指向终端显示器,同样可以通过输出重定向>,让标准错误输出重定向到文件
所谓的输出重定向到文件,是指把默认输出到终端显示器的信息写入到指定文件
标准输入,标准输出,标准错误输出的文件描述符分别时0,1,2。
上面命令中
command 为要执行的命令
> 表示输出重定向
file 表示要重定向的文件名
2和1 分别指标准错误输出和标准输出,
而&1表示标准输出的引用,所以2>&1是指把标准错误输出重定向到标准输出的引用,即也重定向到file
例子
脚本
#!/bin/sh
t //t命令不存在,会产生标准错误输出
date //会产生标准输出
执行脚本:未重定向的情况下标准错误输出和标准输出都显示在终端显示器
[vagrant@vmp2-local-dva01 ~]$ sh /var/www/pyxis2/system/fortest/test1.sh /var/www/pyxis2/system/fortest/test1.sh: line 3: t: コマンドが見つかりません //标准错误输出显示到显示器 2019年 1月 18日 金曜日 18:43:37 JST //标准输出显示到显示器 [vagrant@vmp2-local-dva01 ~]$
标准输出重定向到testlog文件,标准错误输出不重定向
[vagrant@vmp2-local-dva01 ~]$ sh /var/www/pyxis2/system/fortest/test1.sh > testlog
/var/www/pyxis2/system/fortest/test1.sh: line 3: t: コマンドが見つかりません //标准错误输出未重定向,错误信息默认显示到显示器 [vagrant@vmp2-local-dva01 ~]$ cat testlog //标准输出重定向到testlog文件,所以标准输出写入到testlog文件,而没有显示到显示器 2019年 1月 18日 金曜日 18:50:22 JST [vagrant@vmp2-local-dva01 ~]$
command >file 就相当于 command 1>file
标准输出不重定向,标准错误输出重定向到testlog
[vagrant@vmp2-local-dva01 ~]$ sh /var/www/pyxis2/system/fortest/test1.sh 2> testlog 2019年 1月 18日 金曜日 18:58:20 JST //标准输出未重定向,标准输出默认输出到显示器 [vagrant@vmp2-local-dva01 ~]$ cat testlog //标准错误输出重定向到testlog文件,所以错误信息写入到testlog文件,而没有在显示器显示 /var/www/pyxis2/system/fortest/test1.sh: line 3: t: コマンドが見つかりません [vagrant@vmp2-local-dva01 ~]$
标准输出重定向到testlog1,标准错误输出重定向到testlog2
[vagrant@vmp2-local-dva01 ~]$ sh /var/www/pyxis2/system/fortest/test1.sh >testlog1 2>testlog2 [vagrant@vmp2-local-dva01 ~]$ cat testlog1 2019年 1月 18日 金曜日 19:04:32 JST [vagrant@vmp2-local-dva01 ~]$ cat testlog2 /var/www/pyxis2/system/fortest/test1.sh: line 3: t: コマンドが見つかりません [vagrant@vmp2-local-dva01 ~]$
标准输出重定向到文件testlog,标准错误输出重定向到标准输出的引用
[vagrant@vmp2-local-dva01 ~]$ sh /var/www/pyxis2/system/fortest/test1.sh >testlog 2>&1 [vagrant@vmp2-local-dva01 ~]$ cat testlog /var/www/pyxis2/system/fortest/test1.sh: line 3: t: コマンドが見つかりません 2019年 1月 18日 金曜日 19:06:45 JST [vagrant@vmp2-local-dva01 ~]$
标准错误输出重定向到文件testlog,标准输出和重定向到标准错误输出的引用
[vagrant@vmp2-local-dva01 ~]$ sh /var/www/pyxis2/system/fortest/test1.sh 2>testlog 1>&2 [vagrant@vmp2-local-dva01 ~]$ cat testlog /var/www/pyxis2/system/fortest/test1.sh: line 3: t: コマンドが見つかりません 2019年 1月 18日 金曜日 19:08:29 JST [vagrant@vmp2-local-dva01 ~]$
标准输出重定向到testlog文件,标准错误输出也重定向到testlog文件
[vagrant@vmp2-local-dva01 ~]$ sh /var/www/pyxis2/system/fortest/test1.sh 1>testlog 2>testlog [vagrant@vmp2-local-dva01 ~]$ cat testlog 2019年 1月 18日 金曜日 19:10:17 JST ne 3: t: コマンドが見つかりません //输出不完全 [vagrant@vmp2-local-dva01 ~]$
command>a 2>a 与 command>a 2>&1的区别
对于command>a 2>&1这条命令,等价于command 1>a 2>&1
可以理解为执行command产生的标准输入重定向到文件a中,标准错误也重定向到文件a中。
那么是否就说command 1>a 2>&1等价于command 1>a 2>a呢。
其实不是,command 1>a 2>&1与command 1>a 2>a还是有区别的,区别就在于前者只打开一次文件a,后者会打开文件两次,并导致stdout被stderr覆盖,可能导致某些输出错误。
&1的含义就可以理解为用标准输出的引用,引用的就是重定向标准输出产生打开的a。从IO效率上来讲,command 1>a 2>&1比command 1>a 2>a的效率更高。