一、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文件中。如果用nohup同时运行了同目录中的多个命令,所有输出都将发送到同一个nohup.out文件中,输出结果会让人感到困惑。



nohup 命令运行由 Command参数和任何相关的 Arg参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使用 nohup 命令运行后台中的程序。要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部。


二.nohup.out的查看方式与方法

实际使用过程中,往往人们为了省心(嗯,没错,就是懒),经常没有给nohup.out进行重定向输出,也没有按日期分割文件,会造成这个文件特别巨大,达到2G或者3G,这个使用想查看文件,搜索出错内容就比较痛苦了。一般有两种方式

1.linux本机查看:使用tail 命令,查看最新的日志,或滚动监控日志打印。

例如

tail -1000 nohup.out  (查看最后1000行日志文本) 
tail -f nohup.out (监控日志打印)

2.ftp下载到windown主机查看:一般小的log文件都没有问题,但是过G的,一般的文本文档查看就显得无力了。推荐使用UltraEdit进行打开。

nohup.out 文件的前世今生_bash

三、删掉会怎么样?

首先,​不能直接删除​。如上文所述出现了超大号的文件简直是令人讨厌的事情,而且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 &