Linux下nohup實(shí)現(xiàn)后臺(tái)運(yùn)行程序及查看(nohup與&)

2024-7-25 / 0 評(píng)論 / 1049 閱讀

1. 后臺(tái)執(zhí)行

一般運(yùn)行l(wèi)inux上的程序都是執(zhí)行 .sh 文件(./sh文件),那如果不影響當(dāng)前CMD窗口的操作,需要后臺(tái)運(yùn)行怎么辦呢?

這時(shí)就需要借助 nohup 和 & 命令來(lái)實(shí)現(xiàn)。

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

(1) nohup

加在一個(gè)命令[]的最前面,表[]示不掛斷的運(yùn)[]行命令

(2) &

加載一個(gè)命令[]的最后面,表[]示這個(gè)命令放[]在后臺(tái)執(zhí)行

2. 查看后臺(tái)運(yùn)行的命令

有兩個(gè)命令可[]以來(lái)查看,p[]s 和 jobs。區(qū)[]別在于 jobs 只能查看當(dāng)前[]終端后臺(tái)執(zhí)行[]的任務(wù),換了[]終端就看不見(jiàn)[]了。而ps命[]令適用于查看[]瞬時(shí)進(jìn)程的動(dòng)[]態(tài),可以看到[]別的終端的任[]務(wù)。

(1) jobs

1
2
3
[root@localhost test]# jobs
[1]-  運(yùn)行中               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]+  運(yùn)行中               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 &

先后起了兩個(gè)后臺(tái)運(yùn)行的進(jìn)程,使用jobs后都顯示出來(lái)了。“+”代表最近的一個(gè)任務(wù)(當(dāng)前任務(wù)),“-”代表之前的任務(wù)。

只有在當(dāng)前命令行中使用 nohup和& 時(shí),jobs命令才能將它顯示出來(lái)。如果將他們寫(xiě)到 .sh 腳本中,然后執(zhí)行腳本,是顯示不出來(lái)的

比如執(zhí)行下面這個(gè)腳本后,jobs顯示不出來(lái):

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

這個(gè)是查看進(jìn)程常用的命令,不多說(shuō)了。

a: 顯示所有程序[] u: 以用戶為主的[]格式來(lái)顯示 x: 顯示所有程序[],不以終端機(jī)[]來(lái)區(qū)分

3. 關(guān)閉當(dāng)前后臺(tái)運(yùn)行的程序

kill 命令

(1)通過(guò)jobs命令查看jobnum,然后執(zhí)行 kill %jobnum

(2)通過(guò)ps命令查看進(jìn)程號(hào)PID,然后執(zhí)行 kill %PID

如果是前臺(tái)進(jìn)程的話,直接執(zhí)行 Ctrl+c 就可以終止了

4. 前后臺(tái)進(jìn)程的切換與控制

(1)fg命令

將后臺(tái)中的命[]令調(diào)至前臺(tái)繼[]續(xù)運(yùn)行

如果后臺(tái)中有[]多個(gè)命令,可[]以先用job[]s查看job[]nun,然后[]用 fg %jobnu[]m 將選中的命令[]調(diào)出。

(2)Ctrl + z 命令

將一個(gè)正在前[]臺(tái)執(zhí)行的命令[]放到后臺(tái),并[]且處于暫停狀[]態(tài)

(3)bg命令

將一個(gè)在后臺(tái)[]暫停的命令,[]變成在后臺(tái)繼[]續(xù)執(zhí)行

如果后臺(tái)中有多個(gè)命令,可以先用jobs查看jobnum,然后用 bg %jobnum 將選中的命令調(diào)出繼續(xù)執(zhí)行。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[root@localhost test]# jobs
[1]-  運(yùn)行中               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]+  運(yùn)行中               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 后,將任務(wù)2調(diào)至前臺(tái)運(yùn)行
[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后,將任務(wù)2放置到后臺(tái),并暫停
[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 后,激活任務(wù)2的運(yùn)行
[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 &

評(píng)論一下?

OωO
取消
主站蜘蛛池模板: 国产AV天堂无码一区二区三区| 少妇人妻偷人精品无码视频新浪| 亚洲精品无码一区二区| 人妻丰满熟妇无码区免费| 未满十八18禁止免费无码网站 | 伊人久久精品无码麻豆一区| 精品久久久无码21p发布| 国产午夜av无码无片久久96| 亚洲国产精品无码久久久秋霞2 | 人妻少妇精品无码专区动漫| 久久久久亚洲AV无码专区桃色| 无码国产福利av私拍| 人妻无码久久中文字幕专区| 久久精品无码午夜福利理论片| 狠狠躁天天躁无码中文字幕 | 国产精品爽爽V在线观看无码| 久久精品九九热无码免贵| 国产亚洲美日韩AV中文字幕无码成人| 无码人妻精品一区二区三区夜夜嗨 | 午夜不卡久久精品无码免费| 亚洲äv永久无码精品天堂久久 | 午夜成人无码福利免费视频| 无码国产激情在线观看| 人妻av无码一区二区三区| 最新国产精品无码| 人妻无码中文字幕免费视频蜜桃| 蜜桃AV无码免费看永久| 麻豆aⅴ精品无码一区二区| 日韩人妻无码一区二区三区久久99 | 亚洲成a人在线看天堂无码| 精品久久久无码人妻字幂| 人妻丰满熟妇AV无码区免| 亚洲日韩看片无码电影| 91久久精品无码一区二区毛片| 日韩国产精品无码一区二区三区| 久久成人无码国产免费播放| 国产无遮挡无码视频免费软件| 国产AV无码专区亚洲AV毛网站 | 亚洲成a人无码亚洲成av无码 | 久久久无码精品国产一区| 夜夜添无码一区二区三区|