Linux下nohup實現后臺運行程序及查看(nohup與&)

2024-7-25 / 0 評論 / 1363 閱讀

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
取消
主站蜘蛛池模板: 三上悠亚ssⅰn939无码播放| 久久中文精品无码中文字幕| 99无码人妻一区二区三区免费| 永久免费无码网站在线观看| 人妻少妇无码精品视频区| 东京热人妻无码人av| 国产网红主播无码精品| av区无码字幕中文色| 国产在线无码精品电影网| 久久久久亚洲精品无码网址色欲| 无码一区二区三区视频| 18禁超污无遮挡无码免费网站| 成年轻人电影www无码| 日韩乱码人妻无码中文字幕久久| 天码av无码一区二区三区四区| 亚洲AV永久无码区成人网站| 国产精品无码v在线观看| 亚洲熟妇无码AV| 久久久久亚洲AV无码观看| 亚洲AV永久青草无码精品| 久久精品无码一区二区app| 妖精色AV无码国产在线看| 亚洲av中文无码乱人伦在线观看| 无码国产精品一区二区免费3p| 中文字幕丰满乱孑伦无码专区| 精品无码久久久久久久久久| 亚洲AV中文无码乱人伦在线视色| 无码精品不卡一区二区三区| 无码一区18禁3D| 国产精品无码一区二区三区不卡| 精品无码一区二区三区爱欲九九| 国产精品无码av在线播放| 久久亚洲国产成人精品无码区 | 国产真人无码作爱视频免费| 亚洲精品无码av天堂| 成人免费无码H在线观看不卡 | 久久无码人妻精品一区二区三区| 亚洲?v无码国产在丝袜线观看| 狠狠精品久久久无码中文字幕| 一道久在线无码加勒比| 变态SM天堂无码专区|