Linux下nohup实现后台运行程序及查看(nohup与&)

2024-7-25 / 0 评论 / 515 阅读

1. 后台执行

一般运行linux上的程序都是执行 .sh 文件(./sh文件),那如果不影响当前CMD窗口的操作,需要后台运行怎么办呢?

这时就需要借助 nohup 和 & 命令来实现。

1
nohup java -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M  -jar test.jar $1 $2 $3 &

(1) nohup

加在一个命令[]的最前面,表[]示不挂断的运[]行命令

(2) &

加载一个命令[]的最后面,表[]示这个命令放[]在后台执行

2. 查看后台运行的命令

有两个命令可[]以来查看,p[]s 和 jobs。区[]别在于 jobs 只能查看当前[]终端后台执行[]的任务,换了[]终端就看不见[]了。而ps命[]令适用于查看[]瞬时进程的动[]态,可以看到[]别的终端的任[]务。

(1) jobs

1
2
3
[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/ams/ams-server/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 &

先后起了两个后台运行的进程,使用jobs后都显示出来了。“+”代表最近的一个任务(当前任务),“-”代表之前的任务。

只有在当前命令行中使用 nohup和& 时,jobs命令才能将它显示出来。如果将他们写到 .sh 脚本中,然后执行脚本,是显示不出来的

比如执行下面这个脚本后,jobs显示不出来:

1
2
3
#!/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 &

(2) ps命令

1
2
3
4
[root@localhost test]# ps -aux|grep java
root     21219  0.3  3.9 6258172 148900 pts/0  Sl   10:08   0:02 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
root     21662  0.2  3.0 5041008 116648 pts/0  Sl   10:10   0:01 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
root     23761  0.0  0.0 112664   972 pts/0    S+   10:19   0:00 grep --color=auto java

这个是查看进程常用的命令,不多说了。

a: 显示所有程序[] u: 以用户为主的[]格式来显示 x: 显示所有程序[],不以终端机[]来区分

3. 关闭当前后台运行的程序

kill 命令

(1)通过jobs命令查看jobnum,然后执行 kill %jobnum

(2)通过ps命令查看进程号PID,然后执行 kill %PID

如果是前台进程的话,直接执行 Ctrl+c 就可以终止了

4. 前后台进程的切换与控制

(1)fg命令

将后台中的命[]令调至前台继[]续运行

如果后台中有[]多个命令,可[]以先用job[]s查看job[]nun,然后[]用 fg %jobnu[]m 将选中的命令[]调出。

(2)Ctrl + z 命令

将一个正在前[]台执行的命令[]放到后台,并[]且处于暂停状[]

(3)bg命令

将一个在后台[]暂停的命令,[]变成在后台继[]续执行

如果后台中有多个命令,可以先用jobs查看jobnum,然后用 bg %jobnum 将选中的命令调出继续执行。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[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 &

评论一下?

OωO
取消