当执行shell命令时,会默认打开3个文件,每个文件有对应的文件描述符来方便我们使用
rm -f ${src_tmp_file} > /dev/null 2>&1
类型 | 文件描述符 | 默认情况 | 对应文件句柄位置 |
---|---|---|---|
标准输入(standard input) | 0 | 从键盘获得输入 | /proc/self/fd/0 |
标准输出(standard output) | 1 | 输出到屏幕(即控制台) | /proc/self/fd/1 |
错误输出(error output) | 2 | 输出到屏幕(即控制台) | /proc/self/fd/2 |
- /dev/null 表示空设备文件
- 0 表示stdin标准输入
- 1 表示stdout标准输出
- 2 表示stderr标准错误
>/dev/null
这条命令的作用是将标准输出1重定向到/dev/null
中。 /dev/null
代表linux的空设备文件,所有往这个文件里面写入的内容都会丢失,俗称“黑洞”。那么执行了>/dev/null
之后,标准输出就会不再存在,没有任何地方能够找到输出的内容。
说说2>&1
command > /dev/null其实等价于command 1 > /dev/null,那么对于2>&1也就好理解了,2就是标准错误,1是标准输出,那么这条命令不就是相当于把标准错误重定向到标准输出么。但是是&1而不是1,这里&是什么?这里&相当于等效于标准输出。
2>&1,意思是错误输出等同于标准输出。所以使得,可以rm -f ${src_tmp_file}
把标准输出和错误输出全部输入到dev/null
里。
注意:2>&1,中间不能有空格。
注意:2>&1,必须写在最后,否则会失去原有意义。
&1
对于 &1 更准确的说应该是文件描述符 1,而1标识标准输出,stdout。
2
对于2 ,表示标准错误,stderr。
2>&1 的意思就是将标准错误重定向到标准输出。这里标准输出已经重定向到了 /dev/null。那么标准错误也会输出到/dev/null
rm -f ${src_tmp_file} > /dev/null 2>&1 其实等于
rm -f ${src_tmp_file} 1 > /dev/null 2>&1
rm -f ${src_tmp_file} 1 > /dev/null 2>&1,可以看成三部分: 1.命令:rm -f ${src_tmp_file} 2. 1 > /dev/null:把这条删除命令的标准输出重定向到/dev/null(即不会显示) 3. 2>&1:把错误输出重定向到标准输出,而上面把标准输出重定向到/dev/null,即错误输出也重定向到/dev/null 4. 因此这条命令无论正确执行还是错误,都不会有任何显示
1.前台启动:用户输入命令,直接执行程序
2.后台启动:在命令行尾加入"&"符号,例如后台启动weblogic服务:nohup ./startWeblogic.sh &
所以当你要让程序在后台不挂断运行时,需要将nohup和&一起使用。
例如:nohup ./startWeblogic.sh > /dev/null 2>&1 &
转载:
Linux操作系统管理-/dev/null,_rm -f reout 2>/dev/null-CSDN博客
https://blog.csdn.net/kang19970201/article/details/98968271