kill -STOP 1234 將該進程暫停。
如果要讓它恢複到後台,用kill -CONT 1234 (很多在前台啟動並執行程式這樣是不行的)
如果要恢複到前台,請在當時運行該進程的那個終端用jobs命令查詢暫停進程。
然後用 fg 〔job號〕把進程恢複到前台。
如果jobs只查詢到一個進程,只用 fg 即可。
例:root@dWorks:~# bc -q
[1]+ Stopped bc -q
root@dWorks:~# bc -q
[2]+ Stopped bc -q
root@dWorks:~# jobs
[1]- Stopped bc -q
[2]+ Stopped bc -q
root@dWorks:~# fg 2
bc -q
1+1
2
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,這是由核心來終止進程,進程不能監聽這個訊號。
===================
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的作用,實現了完整的守護進程功能。
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啟動守護進程相應反應會遲緩一些,不適合用於被密集訪問的服務進程