Administrator
发布于 2023-07-03 / 50 阅读
0
0

nohup 2>&1 & Best Practise

背景说明

start.sh 脚本里,写了Java应用程序启动的相关命令,并且在 log4j.properties 中配置了日志的输出路径。
此时,启动服务的时候,如果使用如下命令,则会在start.sh脚本所在的目录下,产生一个名为 nohup.out 的输出文件。这个多余的 nohup.out 文件是不需要的,可以使用如下命令解决:

nohup sh start.sh >/dev/null 2>&1 &

命令解析

nohup &

nohup 表示永久运行, & 表示后台运行

>/dev/null 2>&1

/dev/null 代表空设备文件,也就是不输出任何信息到终端。

操作系统中有三个常用的流:

  • 0:标准输入流 stdin
  • 1:标准输出流 stdout
  • 2:标准错误流 stderr

" >/dev/null" 等价于 “1>/dev/null”,表示标准输出流 输出到 /dev/null 中,即终端不输出标准输出信息;

“2>&1” 中的 “ & ” 是等价于的意思,表示 标准错误流 输出的位置 等价于 标准输出流的位置,即等价于 “2>/dev/null”, 即终端不输出标准错误信息。

因此," >/dev/null 2>&1" 表示 标准错误信息和标准输出信息,在终端上均不输出。

指定输出文件

如果想要将服务启动和运行过程中的日志信息输出到指定位置(比如:/var/log/start.log),可以参考如下命令:

nohup sh start.sh >/var/log/start.log 2>&1 &

评论