要想程序在后台運行,一般這種程序使用 & 結尾,但是如果終端關閉,那么程序也會被關閉。但是為了能夠后台運行,那么我們就可以使用nohup這個命令
nohup sh /usr/local/jboss-4.2.3.GA/bin/run.sh -b 0.0.0.0 &
查看方法
ps -ef |grep java
這個時候關掉SSH程序還會繼續運行
更多可以參考
https://www.ibm.com/developerworks/cn/linux/l-cn-nohup/
fg、bg、jobs、&、nohup、ctrl + z命令
一、&
加在一個命令的最后,可以把這個命令放到后台執行,如gftp &,
二、ctrl + z
可以將一個正在前台執行的命令放到后台,並且處於暫停狀態,不可執行
三、jobs
查看當前有多少在后台運行的命令
jobs -l選項可顯示所有任務的PID,jobs的狀態可以是running, stopped, Terminated,但是如果任務被終止了(kill),shell 從當前的shell環境已知的列表中刪除任務的進程標識;也就是說,jobs命令顯示的是當前shell環境中所起的后台正在運行或者被掛起的任務信息;
四、fg
將后台中的命令調至前台繼續運行
如果后台中有多個命令,可以用fg %jobnumber將選中的命令調出,%jobnumber是通過jobs命令查到的后台正在執行的命令的序號(不是pid)
五、bg
將一個在后台暫停的命令,變成繼續執行 (在后台執行)
如果后台中有多個命令,可以用bg %jobnumber將選中的命令調出,%jobnumber是通過jobs命令查到的后台正在執行的命令的序號(不是pid)
將任務轉移到后台運行:
先ctrl + z;再bg,這樣進程就被移到后台運行,終端還能繼續接受命令。
概念:當前任務
如果后台的任務號有2個,[1],[2];如果當第一個后台任務順利執行完畢,第二個后台任務還在執行中時,當前任務便會自動變成后台任務號碼“[2]” 的后台任務。所以可以得出一點,即當前任務是會變動的。當用戶輸入“fg”、“bg”和“stop”等命令時,如果不加任何引號,則所變動的均是當前任務
六:nohup
如果你正在運行一個進程,而且你覺得在退出帳戶時該進程還不會結束,那么可以使用nohup命令。該命令可以在你退出帳戶/關閉終端之后繼續運行相應的進程。
進程的終止
后台進程的終止:
方法一:
通過jobs命令查看job號(假設為num),然后執行kill %num
方法二:
通過ps命令查看job的進程號(PID,假設為pid),然后執行kill pid
前台進程的終止:
ctrl+c
kill的其他作用
kill除了可以終止進程,還能給進程發送其它信號,使用kill -l 可以察看kill支持的信號。
SIGTERM是不帶參數時kill發送的信號,意思是要進程終止運行,但執行與否還得看進程是否支持。如果進程還沒有終止,可以使用kill -SIGKILL pid,這是由內核來終止進程,進程不能監聽這個信號。
進程的掛起(暫停的意思吧)
后台進程的掛起:
在solaris中通過stop命令執行,通過jobs命令查看job號(假設為num),然后執行stop %num;
在redhat中,不存在stop命令,可通過執行命令kill -stop PID,將進程掛起;
當要重新執行當前被掛起的任務時,通過bg %num 即可將掛起的job的狀態由stopped改為running,仍在后台執行;當需要改為在前台執行時,執行命令fg %num即可;
前台進程的掛起:
ctrl+Z;
使用jobs 查看任務。 使用fg %n 關閉。
================================================
LINUX任務(jobs)詳解 (轉)
LINUX任務(jobs)詳解
在用管理員執行一個命令后,用Ctrl+Z把命令轉移到了后台。導致無法退出root的。
輸入命令:exit
終端顯示:There are stopped jobs.
解決方法:
方法一、輸入命令:jobs
終端顯示:[1]+ Stopped vim /etc/network/interfaces > /home/leo/Desktop/ip.txt (wd: /)
KILL %1
方法二、輸入命令:jobs -l
終端顯示:[1]+ 4664 停止 vim /etc/network/interfaces > /home/leo/Desktop/ip.txt (wd: /)
看到4664,這個就是PID了
現在開始殺掉它:
輸入命令:kill 4664
終端沒有顯示。ok。
再用jobs命令查看,確認已經殺掉了
A,Shell支持作用控制,有以下命令:
1. command& 讓進程在后台運行
2. jobs 查看后台運行的進程
3. fg %n 讓后台運行的進程n到前台來
4. bg %n 讓進程n到后台去;
PS:"n"為jobs查看到的進程編號.
B.下列轉:http://blog.chinaunix.net/u/1604/showart_1079559.html
fg、bg、jobs、&、ctrl + z都是跟系統任務有關的,雖然現在基本上不怎么需要用到這些命令,但學會了也是很實用的
一。& 最經常被用到
這個用在一個命令的最后,可以把這個命令放到后台執行
二。ctrl + z
可以將一個正在前台執行的命令放到后台,並且暫停
三。jobs
查看當前有多少在后台運行的命令
四。fg
將后台中的命令調至前台繼續運行
如果后台中有多個命令,可以用 fg %jobnumber將選中的命令調出,%jobnumber是通過jobs命令查到的后台正在執行的命令的序號(不是pid)
五。bg
將一個在后台暫停的命令,變成繼續執行
如果后台中有多個命令,可以用bg %jobnumber將選中的命令調出,%jobnumber是通過jobs命令查到的后台正在執行的命令的序號(不是pid)
#Linux下使用Shell命令控制任務Jobs執行
ps 列出系統中正在運行的進程;
kill 發送信號給一個或多個進程(經常用來殺死一個進程);
jobs 列出當前shell環境中已啟動的任務狀態,若未指定jobsid,則顯示所有活動的任務狀態信息;如果報告了一個任務的終止(即任務的狀態被標記為Terminated),shell 從當前的shell環境已知的列表中刪除任務的進程標識;
bg 將進程搬到后台運行(Background);
fg 將進程搬到前台運行(Foreground);
將job轉移到后台運行
如果你經常在X圖形下工作,你可能有這樣的經歷:通過終端命令運行一個GUI程序,GUI界面出來了,但是你的終端還停留在原地,你不能在shell中繼續執行其他命令了,除非將GUI程序關掉。
為了使程序執行后終端還能繼續接受命令,你可以將進程移到后台運行,使用如下命令運行程序: #假設要運行xmms
$xmms &
這樣打開xmms后,終端的提示又回來了。現在xmms在后台運行着呢;但萬一你運行程序時忘記使用“&”了,又不想重新執行;你可以先使用ctrl+z掛起程序,然后敲入bg命令,這樣程序就在后台繼續運行了。
概念:當前任務
如果后台的任務號有2個,[1],[2];如果當第一個后台任務順利執行完畢,第二個后台任務還在執行中時,當前任務便會自動變成后台任務號碼“[2]”的后台任務。所以可以得出一點,即當前任務是會變動的。當用戶輸入“fg”、“bg”和“stop”等命令時,如果不加任何引號,則所變動的均是當前任務。
察看jobs
使用jobs或ps命令可以察看正在執行的jobs。
jobs命令執行的結果,+表示是一個當前的作業,減號表是是一個當前作業之后的一個作業,jobs -l選項可顯示所有任務的PID,jobs的狀態可以是running, stopped, Terminated,但是如果任務被終止了(kill),shell 從當前的shell環境已知的列表中刪除任務的進程標識;也就是說,jobs命令顯示的是當前shell環境中所起的后台正在運行或者被掛起的任務信息;
進程的掛起
后台進程的掛起:
在solaris中通過stop命令執行,通過jobs命令查看job號(假設為num),然后執行stop %num;
在redhat中,不存在stop命令,可通過執行命令kill -stop PID,將進程掛起;
當要重新執行當前被掛起的任務時,通過bg %num 即可將掛起的job的狀態由stopped改為running,仍在后台執行;當需要改為在前台執行時,執行命令fg %num即可;
前台進程的掛起:
ctrl+Z;
進程的終止
后台進程的終止:
方法一:
通過jobs命令查看job號(假設為num),然后執行kill %num
方法二:
通過ps命令查看job的進程號(PID,假設為pid),然后執行kill pid
前台進程的終止:
ctrl+c
kill的其他作用
kill除了可以終止進程,還能給進程發送其它信號,使用kill -l 可以察看kill支持的信號。
SIGTERM是不帶參數時kill發送的信號,意思是要進程終止運行,但執行與否還得看進程是否支持。如果進程還沒有終止,可以使用kill -SIGKILL pid,這是由內核來終止進程,進程不能監聽這個信號。
附:nohup命令參考
在守護進程中,最重要的一個是超級 守護進程inetd,這個進程接管了大部分網絡服務,但並不是對每 個服務都自己進行處理,而是依據連接請求,啟動不同的服務程序與客戶機打交道。inetd支持網絡服務種類在它的設置文件/etc/inet.conf中 定義。inet.conf文件中的每一行就對應一個端口地址,當inetd接受到連接這個端口的連接請求時,就啟動相應的進程進行處理。使用inetd的 好處是系統不必啟動很多守護進程,從而節約了系統資源,然而使用inetd啟動守護進程相應反應會遲緩一些,不適合用於被密集訪問的服務進程。