先说一下linux重定向:
0:标准输入
1:标准输出
2:标准错误信息输出
在一般使用时,默认的是标准输出,既1.当我们需要特殊用途时,可以使用其他标号。例如,将某个程序的错误信息输出到log文件中:./program 2>log。这样标准输出还是在屏幕上,但是错误信息会输出到log文件中。
另外,也可以实现0,1,2之间的重定向。
2>&1:将错误信息重定向到标准输出。
前台运行程序时,该程序会一直占用着终端如果有屏幕输出的话屏幕会一直打印,这时候我们让程序后台运行(可能会一直打印,但不会占用终端),在程序运行命令最后加上 【&].
使用&后台运行程序:
-
结果会输出到终端
-
使用Ctrl + C发送SIGINT信号,程序免疫
-
关闭session发送SIGHUP信号,程序关闭
使用nohup运行程序:
-
结果默认会输出到nohup.out
-
使用Ctrl + C发送SIGINT信号,程序关闭
-
关闭session发送SIGHUP信号,程序免疫
平日线上经常使用nohup和&配合来启动程序:
-
同时免疫SIGINT和SIGHUP信号
同时,还有一个最佳实践:
-
不要将信息输出到终端标准输出,标准错误输出,而要用日志组件将信息记录到日志里
【nohup】+【&】这样程序就可以在后台运行且关闭窗口也对其没有影响
Linux下还有一个特殊的文件/dev/null,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null。将所有输出重定向到【/dev/null】这个‘空’设备文件,它会丢弃写入的内容,就感觉任何东西都被“宇宙黑洞”吞噬了一样。
1.如果想要正常输出和错误信息都不显示,则要把标准输出和标准错误都重定向到/dev/null
ls 1>/dev/null 2>/dev/null
2. 将错误重定向到标准输出,然后再重定向到 /dev/null
ls >/dev/null 2>&1
注意:此处的顺序不能更改,否则达不到想要的效果,此时先将标准输出重定向到 /dev/null,然后将标准错误重定向到标准输出,由于标准输出已经重定向到了/dev/null,因此标准错误也会重定向到/dev/null,于是一切静悄悄
由于使用nohup时,会自动将输出写入nohup.out文件中,如果文件很大的话,nohup.out就会不停的增大,这是我们不希望看到的,因此,可以利用/dev/null来解决这个问题。
a) 将标准输出重定向到 /dev/null,然后将标准错误重定向log文件
nohup ./program >/dev/null 2>log & #将program的错误信息输出到log文件,其他信息丢进/dev/null
b) 将标准错误重定向到标准输出,由于标准输出已经重定向到了/dev/null
nohup ./program >/dev/null 2>&1 & #将program的错误信息重定向到标准输出,其他信息丢进/dev/null