关于nohup.out
nohup.out
的由来及作用
- 用途:LINUX命令用法,不挂断地运行命令
- 语法:
nohup Command [ Arg ... ] [ & ]
- 描述:
nohup
命令运行由 Command 参数和任何相关的Arg
参数指定的命令,忽略所有挂断(SIGHUP
)信号。在注销后使用nohup
命令运行后台中的程序。要运行后台中的nohup
命令,添加 & ( 表示“and”的符号)到命令的尾部 - 例子:
nohup ./startWeblogic.sh &
意思是即使退出ssh界面,命令仍然在后台执行,并且打印过程日志到nohup.out
,当然也可以将nohup.out
的输出转向到其他文件,高级应用请参考扩展阅读
nohup.out
的查看方式
实际使用过程中,往往人们为了省心(嗯,没错,就是懒),经常没有给nohup.out
进行重定向输出,也没有按日期分割文件,会造成这个文件特别巨大,这个使用想查看文件,搜索出错内容就比较痛苦了。一般有两种方式
Linux本机查看:使用
tail
命令,查看最新的日志,或滚动监控日志打印。例如命令
tail -1000 nohup.out
(查看最后1000行日志文本)tail -f nohup.out
(监控日志打印)ftp
下载到windows
主机查看:一般小的log文件都没有问题,但是过G的,一般的文本文档查看就显得无力了。推荐使用UltraEdit
进行打开
nohup.out维护管理方法(清空nohop.out)
如上文所述出现了超大号的文件简直是令人讨厌的事情,而且nohup.out
会一直一直自己增长下去,如果你的服务器硬盘不给力的话,很容易把应用也挂掉(硬盘没空间 ,啥都玩不转),但是又不能一味的直接删。因为直接删除,可能会造成应用无法打印后续的错误日志,该问题常见于weblogic
服务器,jboss
服务器等这些大型中间件,这个在生产环境上要尤为注意。因此就有了我们不停止服务直接,清空nohup.out
文件的方法。
两个可以不用停止WEB服务就可以清空nohup.out
的命令:
cp /dev/null nohup.out
cat /dev/null > nohup.out
扩展阅读
nohup
的重定向,一劳永逸解决nohup.out
文件过大的问题
以下是定义日志打印级别,除了高于级别2的告警信息记录到log文件外,其余直接不记录
- 只输出错误信息到日志文件:
nohup ./program >/dev/null 2>log &
- 什么信息也不要:
nohup ./program >/dev/null 2>&1 &
Linux的3中重定向
- 0:表示标准输出
- 1:标准输出,在一般使用时,默认的是标准输出
- 2:标准错误信息输出
- 可以用来指定需要重定向的标准输入或输出。例如,将某个程序的错误信息输出到log文件中:
./program 2>log
。这样标准输出还是在屏幕上,但是错误信息会输出到log文件中。另外,也可以实现0,1,2之间的重定向。2>&1:将错误信息重定向到标准输出
关于/dev/null
文件
Linux下还有一个特殊的文件/dev/null
,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null
。