下列命令能夠用來操縱進程任務:
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,這是由內核來終止進程,進程不能監聽這個信號。
===================
Unix/Linux下通常想讓某個程序在後臺運行,不少都是使用 & 在程序結尾來讓程序自動運行。好比咱們要運行mysql在後臺:
/usr/local/mysql/bin/mysqld_safe --user=mysql &
可是咱們不少程序並不象mysqld同樣能夠作成守護進程,可能咱們的程序只是普通程序而已,通常這種 程序即便使用 & 結尾,若是終端關閉,那麼程序也會被關閉。爲了可以後臺運行,咱們須要使用nohup這個命令,好比咱們有個start.sh須要在後臺運行,而且但願在 後臺可以一直運行,那麼就使用nohup:
nohup /root/start.sh &
在shell中回車後提示:
[~]$ appending output to nohup.out
原程序的的標準輸出被自動改向到當前目錄下的nohup.out文件,起到了log的做用。
可是有時候在這一步會有問題,當把終端關閉後,進程會自動被關閉,察看nohup.out能夠看到在關閉終端瞬間服務自動關閉。
諮詢紅旗Linux工程師後,他也不得其解,在個人終端上執行後,他啓動的進程居然在關閉終端後依然運行。
在 第二遍給我演示時,我才發現我和他操做終端時的一個細節不一樣:他是在當shell中提示了nohup成 功後還須要按終端上鍵盤任意鍵退回到shell輸入命令窗口,而後經過在shell中輸入exit來退出終端;而我是每次在nohup執行成功後直接點關 閉程序按鈕關閉終端.。因此這時候會斷掉該命令所對應的session,致使nohup對應的進程被通知須要一塊兒shutdown。
這個細節有人和我同樣沒注意到,因此在這兒記錄一下了。
附:nohup命令參考
nohup 命令
用途:不掛斷地運行命令。
語法:nohup Command [ Arg ... ] [ & ]
描述:nohup 命令運行由 Command 參數和任何相關的 Arg 參數指定的命令,忽略全部掛斷(SIGHUP)信號。在註銷後使用 nohup 命令運行後臺中的程序。要運行後臺中的 nohup 命令,添加 & ( 表示"and"的符號)到命令的尾部。
不管是否將 nohup 命令的輸出重定向到終端,輸出都將附加到當前目錄的 nohup.out 文件中。若是當前目錄的 nohup.out 文件不可寫,輸出重定向到 $HOME/nohup.out 文件中。若是沒有文件能建立或打開以用於追加,那麼 Command 參數指定的命令不可調用。若是標準錯誤是一個終端,那麼把指定的命令寫給標準錯誤的全部輸出做爲標準輸出重定向到相同的文件描述符。
退出狀態:該命令返回下列出口值:
126 能夠查找但不能調用 Command 參數指定的命令。
127 nohup 命令發生錯誤或不能查找由 Command 參數指定的命令。
不然,nohup 命令的退出狀態是 Command 參數指定命令的退出狀態。
nohup命令及其輸出文件
nohup命令:若是你正在運行一個進程,並且你以爲在退出賬戶時該進程還不會結束,那麼可使用nohup命令。該命令能夠在你退出賬戶/關閉終端以後繼續運行相應的進程。nohup就是不掛起的意思( n ohang up)。
該命令的通常形式爲:nohup command &
使用nohup命令提交做業
若是使用nohup命令提交做業,那麼在缺省狀況下該做業的全部輸出都被重定向到一個名爲nohup.out的文件中,除非另外指定了輸出文件:
nohup command > myout.file 2>&1 &
在上面的例子中,輸出被重定向到myout.file文件中。
使用 jobs 查看任務。
使用 fg %n 關閉。
另外有兩個經常使用的ftp工具ncftpget和ncftpput,能夠實現後臺的ftp上傳和下載,這樣就能夠利用這些命令在後臺上傳和下載文件了。
簡單而有用的nohup命令在UNIX/LINUX中,普通進程用&符號放到後臺運行,若是啓動該程序的控制檯logout,則該進程隨即終止。
要實現守護進程,一種方法是按守護進程的規則去編程(本站有文章介紹過),比較麻煩;另外一種方法是仍然用普通方法編程,而後用nohup命令啓動程序:
nohup<程序名>&
則控制檯logout後,進程仍然繼續運行,起到守護進程的做用(雖然它不是嚴格意義上的守護進程)。
使用nohup命令後,原程序的的標準輸出被自動改向到當前目錄下的nohup.out文件,起到了log的做用,實現了完整的守護進程功能。
ygwu @ 2005年04月18日 上午10:03
For example:
如何遠程啓動WebLogic服務?
用telnet遠程控制服務器,遠程啓動WEBLOGIC服務,啓動後關閉telnet,WebLogic服務也跟着中止,這是由於使用telnet啓動的進程會隨着telnet進程的關閉而關閉。因此咱們可使用一些UNIX下的命令來作到不關閉。
使用以下命令:
nohup startWeblogic.sh&
若是想要監控標準輸出可使用:
tail -f nohup.out
當在後臺運行了程序的時候,能夠用jobs命令來查看後臺做業的狀態。在有多個後臺程序時,要使用來參數的fg命令將不一樣序號的後臺做業切換到前臺上運行。
當用戶啓動一個進程的時候,這個進程是運行在前臺,使用與相應控制終端相聯繫的標準輸入、輸出進行輸 入和輸出。即便將進程的輸入輸出重定向,並將進程放在後臺執行,進程仍然和當前終端設備有關係。正由於如此,在當前的登陸會話結束時,控制終端設備將和登 錄進程相脫離,那麼系統就向全部與這個終端相聯繫的進程發送SIGHUP的信號,通知進程線路已經掛起了,若是程序沒有接管這個信號的處理,那麼缺省的反 應是進程結束。所以普通的程序並不能真正脫離登陸會話而運行進程,爲了使得在系統登陸後還能夠正常執行,只有使用命令nohup來啓動相應程序。
使用命令nohup固然能夠啓動這樣的程序,但nohup啓動的程序在進程執行完畢就退出,而常見的 一些服務進程一般永久的運行在後臺,不向屏幕輸出結果。在Unix中這些永久的後臺進程稱爲守護進程(daemon)。守護進程一般從系統啓動時自動開始 執行,系統關閉時才中止。
在守護進程中,最重要的一個是超級 守護進程inetd,這個進程接管了大部分網絡服務,但並非對每 個服務都本身進行處理,而是依據鏈接請求,啓動不一樣的服務程序與客戶機打交道。inetd支持網絡服務種類在它的設置文件/etc/inet.conf中 定義。inet.conf文件中的每一行就對應一個端口地址,當inetd接受到鏈接這個端口的鏈接請求時,就啓動相應的進程進行處理。使用inetd的 好處是系統沒必要啓動不少守護進程,從而節約了系統資源,然而使用inetd啓動守護進程相應反應會遲緩一些,不適合用於被密集訪問的服務進程。session