A,Shell支援作用控制,有以下指令:
1. command& 讓程序在背景運作
2. jobs 檢視背景運作的程序
3. fg %n 讓背景運作的程序n到前台來
4. bg %n 讓程序n到背景去;
PS:"n"為jobs檢視到的程序編号.
B. 指令詳解
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的作用,實作了完整的守護程序功能。 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啟動守護程序相應反應會遲緩一些,不适合用于被密集通路的服務程序 引用自: http://hi.baidu.com/flying5/blog/item/70ff8fdd4a3e60d28c10292b.html