一、前言
经常看到一些jar包,sh脚本用nohup命令后台启动,今天就讲解一下nohup的用法。
nohup主要作用就是可以在后台运行,并可以选择将日志输出到指定文件。如启动jar包,若使用java -jar demo.jar的方式启动程序当窗口关闭的时候程序也停止了,而且日志会直接输出到控制台非常不直观,nohup启动就可以解决这两个问题。
二、nohup(不挂断)简介
nohup 是 no hung up的缩写,意思是不挂断 。
nohup 命令,在默认情况下(非重定向时),会输出一个名叫 nohup.out 的文件到当前目录下,如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。
使用 Xshell 等Linux 客户端工具,远程执行 Linux 脚本时,有时候会由于网络问题,导致客户端失去连接,终端断开,脚本运行一半就意外结束了。这种时候,就可以用nohup 指令来运行指令,即使客户端与服务端断开,服务端的脚本仍可继续运行。
nohup 语法格式:
nohup 命令 [参数]...
说明:
关闭客户端后,命令仍然会运行,不会挂断。
nohup命令允许被运行的程序的输出信息将不会显示到终端。
三、nohup使用
3.1、nohup启动
nohup sh test.sh
说明:
后台启动test.sh脚本,日志默认会输出到当前目录的nohup.out 文件
3.2、nohup与&,后台运行
&符号表示将该命令或脚本放入后台运行。 即&方式启动会有进程号,使用Ctrl+C程序不会中断,但终端关闭后运行会中断。
nohup sh test.sh &
3.3、nohup与>,日志重定向
上面提到的日志文件默认名称是 nohup.out ,如果修改日志文件的名称,则用到 重定向 ,符号是>,语法格式是
nohup sh test.sh >test.log
>表示标准输出,还可以用>,>>, 1>或1>>等进行表示
3.4、nohup后台启动-综合使用(推荐)
# 后台执行test.sh文件,将标准日志输出到output.log文件中,将错误日志也输出到output.log文件中
nohup ./test.sh > output.log 2>&1 &
等同于
nohup ./test.sh > output.log 2>output.log &
说明:
">"符号用于将命令的`标准输出`重定向到指定的文件中
> outlog.log 表示将终端输出保存到outlog.log文件中
"2>"表示将命令的`标准错误`输出重定向到指定的文件中
2>&1 表示将命令的标准错误输出重定向到标准输出1中一起输出 (ps:标准输出1指的是>outlog.log文件,具体可见下面的内容)
& 后台挂起
2>&1
>符号用于将命令的标准输出重定向到指定的文件中,
2>表示将命令的标准错误输出重定向到指定的文件中,
2>&1表示将命令的标准错误输出重定向到标准输出中
在Linux系统中0 1 2是一个文件描述符
几种输入输出方式 文件描述符 操作符 java中表示 说明
标准输入(stdin),即standard input 0 <或<< System.in 即表示键盘输入
标准输出(stdout),即standard output 1 >,>>, 1>或1>> System.out 例如,运行"ls 文件"命令将会输出当前工作目录下的文件列表,这些信息将会被输出到标准输出中并显示在终端上。
标准错误输出(stderr),即standard error output 2 2>或2>> System.err 例如,运行"ls 文件"命令,但是不存在此文件,那么将会输出错误信息"ls:cannot access ‘文件名’:No such file or directory",这个错误信息将会被输出到标准错误输出中并显示在终端上。
3.5、nohup后台启动(不生成日志)
上面的示例中,都会将nohup执行的日志存放到nohup.out文件或者其他文件中,有没有方法不存放日志了呢?请使用以下命令
#/dev/null 表示空设备文件。 如果不想输出任何的日志时,使用此参数 。
nohup ./test.sh >/dev/null &
四、查看进程
nohup test.sh >out.log 2&1 &
ps -aux | grep "test.sh"
参数说明:
a: 显示所有程序
u: 以用户为主的格式来显示
x: 显示所有程序,不区分终端机
五、知识扩展
5.1、不停止服务,直接清空nohup.out
如果脚本一直运行下去,nohup.out 日志会一直增长,日志但是硬盘容量有限,怎么把日志文件的大小减少 ?
注意,千万别直接删除日志文件,会造成服务无法输出日志,服务异常直接停止运行,这是最严重生产事故。
不停止服务,直接清空nohup.out文件有两种方法:
# 第1种:
cat /dev/null > nohup.out
# 第2种:
cp /dev/null nohup.out
5.2、只记录警告级别比较高的日志
输出的日志太多,nohup.out 增长特别快,对于不重要的日记,可以不记录,选择只记录警告级别比较高的日志。
# 只输出错误信息到日志文件,其它日志不输出
nohup ./test.sh > /dev/null 2>error.log &
5.3、不想输出日志
不想输出日志,什么日志都不要,只要服务能正常运行就行了。
# 什么日志也不输出
nohup ./test.sh > /dev/null 2>&1 &
如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!
添加我为好友,拉您入交流群!
请使用微信扫一扫!