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)論一下?