Linux nohup实现后台运行程序及查看(nohup与)
Linux nohup實現(xiàn)后臺運行程序及查看(nohup與&)
更新時間:2019年09月11日 09:28:40 作者:猿的生活
這篇文章主要介紹了Linux nohup實現(xiàn)后臺運行程序及查看(nohup與&),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
1. 后臺執(zhí)行
一般運行l(wèi)inux上的程序都是執(zhí)行 .sh 文件(./sh文件),那如果不影響當(dāng)前CMD窗口的操作,需要后臺運行怎么辦呢?
這時就需要借助 nohup 和 & 命令來實現(xiàn)。
nohup` `java -server -Xms128M -Xmx512M -XX:MetaspaceSize=128M -jar ``test``.jar $1 $2 $3 &(1) nohup
加在一個命令的最前面,表示不掛斷的運行命令
(2) &
加載一個命令的最后面,表示這個命令放在后臺執(zhí)行
2. 查看后臺運行的命令
有兩個命令可以來查看,ps 和 jobs。區(qū)別在于 jobs 只能查看當(dāng)前終端后臺執(zhí)行的任務(wù),換了終端就看不見了。而ps命令適用于查看瞬時進(jìn)程的動態(tài),可以看到別的終端的任務(wù)。
(1) jobs
[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 &先后起了兩個后臺運行的進(jìn)程,使用jobs后都顯示出來了。“+”代表最近的一個任務(wù)(當(dāng)前任務(wù)),“-”代表之前的任務(wù)。
只有在當(dāng)前命令行中使用 nohup和& 時,jobs命令才能將它顯示出來。如果將他們寫到 .sh 腳本中,然后執(zhí)行腳本,是顯示不出來的
比如執(zhí)行下面這個腳本后,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 &(2) ps命令
[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這個是查看進(jìn)程常用的命令,不多說了。
a: 顯示所有程序 u: 以用戶為主的格式來顯示 x: 顯示所有程序,不以終端機來區(qū)分
3. 關(guān)閉當(dāng)前后臺運行的程序
kill 命令
(1)通過jobs命令查看jobnum,然后執(zhí)行 kill %jobnum
(2)通過ps命令查看進(jìn)程號PID,然后執(zhí)行 kill %PID
如果是前臺進(jìn)程的話,直接執(zhí)行 Ctrl+c 就可以終止了
4. 前后臺進(jìn)程的切換與控制
(1)fg命令
將后臺中的命令調(diào)至前臺繼續(xù)運行
如果后臺中有多個命令,可以先用jobs查看jobnun,然后用 fg %jobnum 將選中的命令調(diào)出。
(2)Ctrl + z 命令
將一個正在前臺執(zhí)行的命令放到后臺,并且處于暫停狀態(tài)
(3)bg命令
將一個在后臺暫停的命令,變成在后臺繼續(xù)執(zhí)行
如果后臺中有多個命令,可以先用jobs查看jobnum,然后用 bg %jobnum 將選中的命令調(diào)出繼續(xù)執(zhí)行。
[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 后,將任務(wù)2調(diào)至前臺運行 [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放置到后臺,并暫停 [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的運行 [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 &總結(jié)
以上是生活随笔為你收集整理的Linux nohup实现后台运行程序及查看(nohup与)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: tensorflow-计算图
- 下一篇: tensorflow随笔-条件语句-tf