linux nohup.out文件过大解决方法

Linux系统
459
0
0
2022-11-11

Linux的三种重定向

  • 0: 表示标准输入
  • 1: 标准输出,在一般使用时默认的是标准输出
  • 2: 标准错误信息输出,可以用来指定需要重定向的标准输入或输出

在一般使用时,默认的是标准输出,即1.当我们需要特殊用途时,可以使用其他标号。例如,将某个程序的错误信息输出到log文件中:./program 2>log。这样标准输出还是在屏幕上,但是错误信息会输出到log文件中。 另外,也可以实现0,1,2之间的重定向。2>&1:将错误信息重定向到标准输出。 Linux下还有一个特殊的文件/dev/null,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null。

如果想要正常输出和错误信息都不显示,则要把标准输出和标准错误都重定向到/dev/null, 例如:

ls 1>/dev/null 2>/dev/null

还有一种做法是将错误重定向到标准输出,然后再重定向到 /dev/null,例如:

ls >/dev/null 2>&1

注意:此处的顺序不能更改,否则达不到想要的效果,此时先将标准输出重定向到 /dev/null,然后将标准错误重定向到标准输出,由于标准输出已经重定向到了/dev/null,因此标准错误也会重定向到/dev/null,于是一切静悄悄:-)

由于使用nohup时,会自动将输出写入nohup.out文件中,如果文件很大的话,nohup.out就会不停的增大,这是我们不希望看到的,因此,可以利用/dev/null来解决这个问题。

nohup ./program >/dev/null 2>log &

如果错误信息也不想要的话:

nohup ./program >/dev/null 2>&1 &

文件过大解决办法: 1. 手动输入命令,保留nohup.out文件多少行

例如保留10000行,可如下操作:
log=`tail -n 10000 nohup.out`;
echo "$log" > nohup.out

2. 写定时任务,定时清理nohup.out文件

3. 关闭当前的服务,rm -rf 直接删掉,启动服务。注意:如果直接使用rm -rf nohup.out删除,目录中没有这个文件了,但是磁盘空间还是没有减少。这是因为我们的项目正在使用中,就像我们熟悉的Windos系统打开一个文件你是无法删除的。

4. 清空文件内容。这个不需要关闭服务,但是如果项目多,nohup.out 文件多 ,不好定位。

第一种:echo '' > nohup.out
第二种:cp /dev/null nohup.out
第三种:cat /dev/null > nohup.out

5. nohup java -jar test.jar > /var/log/nohup.log &  全部指定到一个文件!

6. 每个项目都是有log的,启动日志就不需要看,直接指定到黑洞目录,在本地也不会保留。

nohup java -jar test.jar > /dev/null 2>&1 &