后台执行
一般运行 linux 上的程序都是执行 .sh
文件(./sh
文件),那如果不影响当前 CMD
窗口的操作,需要后台运行怎么办呢?
这时就需要借助 nohup 和 & 命令来实现。
nohup /usr/local/node/bin/node /www/im/chat.js >> /usr/local/node/output.log 2>&1 &
nohup
用途:加在一个命令的最前面,表示不挂断的运行命令。
语法:nohup Command [ Arg … ] [ & ]
无论是否将 nohup
命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out
文件中。
如果当前目录的 nohup.out
文件不可写,输出重定向到 $HOME/nohup.out
文件中。
如果没有文件能创建或打开以用于追加,那么 Command
参数指定的命令不可调用。
退出状态:该命令返回下列出口值:
126 可以查找但不能调用 Command
参数指定的命令。
127 nohup 命令发生错误或不能查找由 Command
参数指定的命令。
否则,nohup 命令的退出状态是 Command
参数指定命令的退出状态。
&
用途:加载一个命令的最后面,表示这个命令放在后台执行
一般两个一起用
nohup command &
eg:
nohup /usr/local/node/bin/node /www/im/chat.js >> /usr/local/node/output.log 2>&1 &

进程号 7585
关闭当前后台运行的程序
kill 命令
(1)通过 jobs
命令查看 jobnum
,然后执行 kill %jobnum
(2)通过 ps
命令查看进程号 PID
,然后执行 kill %PID
如果是前台进程的话,直接执行 Ctrl+c
就可以终止了
查看后台运行的命令
(1)jobs -l

jobs
命令只看当前终端生效的,关闭终端后,在另一个终端jobs
已经无法看到后台跑得程序了,此时利用 ps(进程查看命令)“+” 代表最近的一个任务(当前任务),“-” 代表之前的任务。
只有在当前命令行中使用 nohup
和 &
时,jobs
命令才能将它显示出来。如果将他们写到 .sh
脚本中,然后执行脚本,是显示不出来的
比如执行下面这个脚本后,jobs
显示不出来:
#!/bin/bash
nohup java -Dfile.encoding=UTF-8 -Dname=Runtime-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test.jar $1 $2 $3 &
ps -ef
ps -aux|grep chat.js
a:显示所有程序
u:以用户为主的格式来显示
x:显示所有程序,不以终端机来区分

注:
> 用 ps -def | grep
查找进程很方便,最后一行总是会 grep
自己
> 用 grep -v
参数可以将 grep
命令排除掉
ps -aux|grep chat.js| grep -v grep

再用 awk
提取一下进程 ID
ps -aux|grep chat.js| grep -v grep | awk ``'{print $2}'

如果某个进程起不来,可能是某个端口被占用
查看使用某端口的进程
lsof -i:8090

netstat -ap|grep 8090

查看到进程id
之后,使用netstat
命令查看其占用的端口
netstat -nap|grep 7779

使用kill杀掉进程后再启动
终止后台运行的进程
kill -9 进程号

前后台进程的切换与控制
fg命令
将后台中的命令调至前台继续运行
如果后台中有多个命令,可以先用 jobs
查看 jobnum
,然后用 fg %jobnum
将选中的命令调出。
Ctrl + z 命令
将一个正在前台执行的命令放到后台,并且处于暂停状态
bg命令
将一个在后台暂停的命令,变成在后台继续执行
如果后台中有多个命令,可以先用 jobs
查看 jobnum
,然后用 bg %jobnum
将选中的命令调出继续执行。
[root@localhost test]# jobs
[1]- 运行中 nohup java -Dfile.encoding=UTF-8 -Dname=Runtime-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test.jar $1 $2 $3 &(工作目录:/home/test)
[2]+ 运行中 nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3 &
// 使用fg 后,将任务2调至前台运行
[root@localhost test]# fg 2
nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3
^Z
// 使用ctrl+Z后,将任务2放置到后台,并暂停
[2]+ 已停止 nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3
// 使用bg 后,激活任务2的运行
[root@localhost test]# bg 2
[2]+ nohup java -Dfile.encoding=UTF-8 -Dname=Container-Name -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -XX:MaxMetaspaceSize=256M -XX:+HeapDumpOnOutOfMemoryError -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar test1.jar $1 $2 $3 &
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
进行重定向输出,也没有按日期分割文件,会造成这个文件特别巨大,达到 2G
或者 3G
,这个使用想查看文件,搜索出错内容就比较痛苦了。一般有两种方式
1.linux本机查看:使用 tail命令,查看最新的日志,或滚动监控日志打印。
例如命令 tail -1000 nohup.out (查看最后1000行日志文本)tail -f nohup.out(监控日志打印)
2.ftp下载到`windown`主机查看:一般小的`log`文件都没有问题,但是过`G`的,一般的文本文档查看就显得无力了。推荐使用`UltraEdit`进行打开。
nohup.out维护管理方法(清空nohup.out)
如上文所述出现了超大号的文件简直是令人讨厌的事情,而且 nohup.out
会一直一直自己增长下去,如果你的服务器硬盘不给力的话,很容易把应用也挂掉(硬盘没空间 ,啥都玩不转),但是又不能一味的直接删。因为直接删除,可能会造成应用无法打印后续的错误日志,该问题常见于 weblogic
服务器,jboss
服务器等这些大型中间件,这个在生产环境上要尤为注意。
因此就有了我们不停止服务直接,清空 nohup.out
文件的方法。
两个可以不用停止 WEB
服务就可以清空 nohup.out
的命令。
第一种:cp /dev/null nohup.out
第二种:cat /dev/null > nohup.out
两个我都用过,不用担心网上所说的性能问题,通常 2/3 个 G
的文件都是 1-2
秒执行完毕
扩展阅读
1.nohup的重定向,一劳永逸解决nohup.out文件过大的问题
以下是定义日志打印级别,除了高于级别 2 的告警信息记录到 log
文件外,其余直接不记录
//只输出错误信息到日志文件
nohup ./program >/dev/null 2>log &
//什么信息也不要
nohup ./program >/dev/null 2>&1 &
2.Linux的3种重定向
0:表示标准输入
1:标准输出,在一般使用时,默认的是标准输出
2:标准错误信息输出
可以用来指定需要重定向的标准输入或输出。例如,将某个程序的错误信息输出到 log
文件中:./program 2>log
。这样标准输出还是在屏幕上,但是错误信息会输出到 log
文件中。另外,也可以实现 0,1,2
之间的重定向。2>&1:
将错误信息重定向到标准输出。
3. 关于 /dev/null 文件 Linux
下还有一个特殊的文件 /dev/null
,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到 /dev/null
。
转自:
https://blog.csdn.net/qq_29663071/article/details/81030396
https://blog.csdn.net/maihilton/article/details/82781897