• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            旅途

            如果想飛得高,就該把地平線忘掉

            Linux——Linux后臺運行命令詳述

            本次主要講述后臺運行命令(crontab,at,&,nohup)及(*,?,[])等

            ? 設置c r o n t a b文件,并用它來提交作業。
            ? 使用a t命令來提交作業。
            ? 在后臺提交作業。
            ? 使用n o h u p命令提交作業。
            名詞解釋:
            cron:系統調度進程。可以使用它在每天的非高峰負荷時間段運行作業,或在一周或一月中的不同時段運行。
            at命令:使用它在一個特定的時間運行一些特殊的作業,或在晚一些的非負荷高峰時間段或高峰負荷時間段運行。
            &:使用它在后臺運行一個占用時間不長的進程。
            nohup:用它在后臺運行一個命令,即使在用戶退出時也不受影響


            1.cron and crontab

            c r o n是系統主要的調度進程,可以在無需人工干預的情況下運行作業。c r o n t a b命令允許用戶提交、編輯或刪除相應的作業。每一個用戶都可以有一個c r o n t a b文件來保存調度信息。可以使用它運行任意一個s h e l l腳本或某個命令,每小時運行一次,或一周三次,這完全取決于你。每一個用戶都可以有自己的c r o n t a b文件,但在一個較大的系統中,系統管理員一般會禁止這些文件,而只在整個系統保留一個這樣的文件。系統管理員是通過c r o n . d e n y和c r o n . a l l o w這兩個文件來禁止或允許用戶擁有自己的c r o n t a b文件。

            crontab的域

            為了能夠在特定的時間運行作業,需要了解c r o n t a b文件每個條目中各個域的意義和格式。

            下面就是這些域:
            代碼:

            第1列分鐘1~5 9
            第2列小時1~2 3(0表示子夜)
            第3列日1~3 1
            第4列月1~1 2
            第5列星期0~6(0表示星期天)
            第6列要運行的命令


            下面是c r o n t a b的格式:
            代碼:

            分< >時< >日< >月< >星期< >要運行的命令


            其中< >表示空格。

            c r o n t a b文件的一個條目是從左邊讀起的,第一列是分,最后一列是要運行的命令,它位于星期的后面。

            可以用橫杠-來表示一個時間范圍,例如你希望星期一至星期五運行某個作業,那么可以在星期域使用1 - 5來表示。
            還可以在這些域中使用逗號“,”,例如你希望星期一和星期四運行某個作業,只需要使用1 , 4來表示。
            可以用星號*來表示連續的時間段。如果你對某個表示時間的域沒有特別的限定,也應該在該域填入*。該文件的每一個條目必須含有5個時間域,而且每個域之間要用空格分隔。
            該文件中所有的注釋行要在行首用#來表示。



            c r o n t a b文件例子:
            代碼:

            30 21* * * /apps/bin/cleanup.sh

            上面的例子表示每晚的2 1 : 3 0運行/ a p p s / b i n目錄下的c l e a n u p . s h。

            代碼:

            45 4 1,10,22 * * /apps/bin/backup.sh

            上面的例子表示每月1、1 0、2 2日的4 : 4 5運行/ a p p s / b i n目錄下的b a c k u p . s h。

            代碼:

            10 1 * * 6,0 /bin/find -name "core" -exec rm {} \;

            上面的例子表示每周六、周日的1 : 1 0運行一個f i n d命令。

            代碼:

            0,30 18-23 * * * /apps/bin/dbcheck.sh

            上面的例子表示在每天1 8 : 0 0至2 3 : 0 0之間每隔3 0分鐘運行/ a p p s / b i n目錄下的d b c h e c k . s h。

            代碼:

            0 23 * * 6 /apps/bin/qtrend.sh

            上面的例子表示每星期六的11 : 0 0 p m運行/ a p p s / b i n目錄下的q t r e n d . s h。

            你可能已經注意到上面的例子中,每個命令都給出了絕對路徑。當使用c r o n t a b運行s h e l l腳本時,要由用戶來給出腳本的絕對路徑,設置相應的環境變量。記住,既然是用戶向c r o n提交了這些作業,就要向c r o n提供所需的全部環境。不要假定c r o n知道所需要的特殊環境,它其實并不知道。所以你要保證在s h e l l腳本中提供所有必要的路徑和環境變量,除了一些自動設置的全局變量。
            如果c r o n不能運行相應的腳本,用戶將會收到一個郵件說明其中的原因。

            c r o n t a b命令的一般形式為:
            代碼:

            crontab [-u user] -e -l -r


            其中:
            -u 用戶名。
            -e 編輯c r o n t a b文件。
            -l 列出c r o n t a b文件中的內容。
            -r 刪除c r o n t a b文件。


            如果使用自己的名字登錄,就不用使用- u選項,因為在執行c r o n t a b命令時,該命令能夠知道當前的用戶。


            創建一個新的crontab文件

            在向c r o n進程提交一個c r o n t a b文件之前,要先設置環境變量E D I TO R.c r o n進程根據它來確定使用哪個編輯器編輯c r o n t a b文件。大部份的U N I X和L I N U X用戶都使用v i,如果你也是這樣,那么你就編輯$ H O M E目錄下的. p r o f i l e文件,在其中加入這樣一行:
            代碼:

            EDITOR=vi; export EDITOR

            然后保存并退出。

            創建一個名為< u s e r > c r o n的文件,其中< u s e r >是用戶名,例如, samcron。在該文件中加入如下的內容。
            代碼:

            #(put your own initials here) echo the date to the console every
            #15 minutes between 6pm and 6am
            0,15,30,45 18-06 * * * /bin/echo 'date' > /dev/console


            保存并退出。確信前面5個域用空格分隔。
            在上面的例子中,系統將每隔1 5分鐘向控制臺輸出一次當前時間。如果系統崩潰或掛起,從最后所顯示的時間就可以一眼看出系統是什么時間停止工作的。在有些系統中,用t t y 1來表示控制臺,可以根據實際情況對上面的例子進行相應的修改。
            為了提交你剛剛創建的c r o n t a b文件,可以把這個新創建的文件作為c r o n命令的參數:
            代碼:

            $su sam
            crontab samcron


            為了方便演示,切換到sam用戶環境下,然后用crontab samcron提交給c r o n進程,它將每隔1 5分鐘運行一次。

            同時,新創建文件的一個副本已經被放在/ v a r / s p o o l / c r o n目錄中,文件名就是用戶名(即sam)。

            代碼:

            #su
            # cat /var/spool/cron/sam
            # DO NOT EDIT THIS FILE - edit the master and reinstall.
            # (samcron installed on Wed Nov 10 21:41:55 2004)
            # (Cron version -- $Id: crontab.c,v 2.13 1994/01/17 03:20:37 vixie Exp $)
            #(put your own initials here) echo the date to the console every
            #15 minutes between 6pm and 6am
            0,15,30,45 18-06 * * * /bin/echo 'date' > /dev/console


            回到root下,查看/var/spool/cron/sam

            列出crontab文件

            為了列出c r o n t a b文件,可以用:
            代碼:

            $ crontab -l
            # DO NOT EDIT THIS FILE - edit the master and reinstall.
            # (samcron installed on Wed Nov 10 21:41:55 2004)
            # (Cron version -- $Id: crontab.c,v 2.13 1994/01/17 03:20:37 vixie Exp $)
            #(put your own initials here) echo the date to the console every
            #15 minutes between 6pm and 6am
            0,15,30,45 18-06 * * * /bin/echo 'date' > /dev/console


            你將會看到和上面類似的內容。可以使用這種方法在$ H O M E目錄中對c r o n t a b文件做一備份:
            代碼:

            $ crontab -l > $HOME/mycron

            這樣,一旦不小心誤刪了c r o n t a b文件,可以用上一節所講述的方法迅速恢復。


            編輯crontab文件

            如果希望添加、刪除或編輯c r o n t a b文件中的條目,而E D I TO R環境變量又設置為v i,那么就可以用v i來編輯c r o n t a b文件,相應的命令為:
            代碼:

            $ crontab -e


            可以像使用v i編輯其他任何文件那樣修改c r o n t a b文件并退出。如果修改了某些條目或添加了新的條目,那么在保存該文件時, c r o n會對其進行必要的完整性檢查。如果其中的某個域出現了超出允許范圍的值,它會提示你。
            例如,加入下面的一條:
            代碼:

            #DT:delete core files,at 3:30am on 1,7,14,21,26 days of each month
            30 3 1,7,14,21,26 * * /bin/find -name "core" -exec rm {} \;


            現在保存并退出。最好在c r o n t a b文件的每一個條目之上加入一條注釋,這樣就可以知道它的功能、運行時間,更為重要的是,知道這是哪位用戶的作業。
            現在讓我們使用前面講過的crontab -l命令列出它的全部信息:
            代碼:

            #(put your own initials here) echo the date to the console every
            #15 minutes between 6pm and 6am
            0,15,30,45 18-06 * * * /bin/echo 'date' > /dev/console

            #DT:delete core files,at 3:30am on 1,7,14,21,26 days of each month
            30 3 1,7,14,21,26 * * /bin/find -name "core" -exec rm {} \;



            刪除crontab文件

            為了刪除c r o n t a b文件,可以用:
            代碼:

            $ crontab -r


            恢復丟失的crontab文件
            如果不小心誤刪了c r o n t a b文件,假設你在自己的$ H O M E目錄下還有一個備份,那么可以將其拷貝到/ v a r / s p o o l / c r o n / < u s e r n a m e >,其中< u s e r n a m e >是用戶名。如果由于權限問題無法完成拷貝,可以用:
            代碼:

            $ crontab <filename>


            其中,< f i l e n a m e >是你在$ H O M E目錄中副本的文件名。
            建議在自己的$ H O M E目錄中保存一個該文件的副本。編輯副本,然后重新提交新的文件。
            有些c r o n t a b的變體有些怪異,所以在使用c r o n t a b命令時要格外小心。如果遺漏了任何選項,c r o n t a b可能會打開一個空文件,或者看起來像是個空文件。這時敲d e l e t e鍵退出,不要按< C t r l - D >,否則你將丟失c r o n t a b文件。



            2.at

            a t命令允許用戶向c r o n守護進程提交作業,使其在稍后的時間運行。一旦一個作業被提交, a t命令將會保留所有當前的環境變量,包括路徑,不象c r o n t a b,只提供缺省的環境。該作業的所有輸出都將以電子郵件的形式發送給用戶,除非你對其輸出進行了重定向,絕大多數情況下是重定向到某個文件中。
            和c r o n t a b一樣,根用戶可以通過/ e t c目錄下的a t . a l l o w和a t . d e n y文件來控制哪些用戶可以使用a t命令,哪些用戶不行。不過一般來說,對a t命令的使用不如對c r o n t a b的使用限制那么嚴格。


            a t命令的基本形式為:
            代碼:

            at [-f script] [-m -l -r] [time] [date]


            其中,
            -f:script 是所要提交的腳本或命令。

            -l:列出當前所有等待運行的作業。a t q命令具有相同的作用。
            -r:清除作業。為了清除某個作業,還要提供相應的作業標識( I D);有些U N I X變體只接受a t r m作為清除命令。
            -m:作業完成后給用戶發郵件。

            time:at命令的時間格式非常靈活;可以是H、H H . H H M M、H H : M M或H : M,其中H和M分別是小時和分鐘。還可以使用a . m .或p . m .。
            date:日期格式可以是月份數或日期數,而且a t命令還能夠識別諸如t o d a y、t o m o r r o w這樣的詞。

            使用at命令提交命令或腳本

            使用a t命令提交作業有幾種不同的形式,可以通過命令行方式,也可以使用a t命令提示符。一般來說在提交若干行的系統命令時,使用a t命令提示符方式,在提交s h e l l腳本時,使用命令行方式。

            提示符方式:
            代碼:

            以在a t命令后面跟上日期/時間并回車。然后就進入了a t命令提示符,這時只需逐條輸入相應的命令,然后按‘ < C T R L - D >’退出。


            命令行方式:
            代碼:

            at [-f script] [-m -l -r] [time] [date]



            例一:提示符方式
            代碼:

            # su sam
            $ at 10:40
            warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh
            at> find /etc -name "passwd" -print
            at> <EOT>
            job 1 at 2004-11-02 10:40


            其中, < E O T >就是< C T R L - D >。在10:40系統將執行一個簡單的f i n d命令。提交的作業被分配了一個唯一標識job 1。該命令在完成以后會將全部結果以郵件的形式發送給我。

            下面這些日期/時間格式都是a t命令可以接受的:
            代碼:

            at 5.00am May23
            at 11.20pm
            at now +2 hour
            at 9am tomorrow
            at 15:00 May24
            at now + 10 minutes


            例二:命令行方式
            如果希望向a t命令提交一個s h e l l腳本,使用其命令行方式即可。在提交腳本時使用- f選項。
            如:
            代碼:

            $ touch db_table.sh
            $ at 3:00pm tomorrow -f db_table.sh
            warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh
            job 3 at 2004-11-02 15:00


            在上面的例子中,一個叫做d b _ t a b l e . s h的腳本將在2004-11-02 15:00運行。

            還可以使用e c h o命令向a t命令提交作業:
            代碼:

            $ echo find /etc -name "passwd" -print | at now +1 minute
            warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh
            job 4 at 2004-11-01 19:07



            列出所提交的作業
            一個作業被提交后,可以使用at -l命令來列出所有的作業:
            代碼:

            $ at -l
            1? ? ? ?2004-11-02 10:40 a sam
            3? ? ? ?2004-11-02 15:00 a sam
            4? ? ? ?2004-11-01 19:07 a sam


            其中,第一行是作業標識,后面是作業運行的日期/時間。最后一列a代表a t。
            還可以使用a t q命令來完成同樣的功能,它是a t命令的一個鏈接。
            直接>atq,相當于>at -l

            當提交一個作業后,它就被拷貝到/ v a r / s p o o l / a t目錄中,準備在要求的時間運行。
            代碼:

            # pwd
            /var/spool/at
            # ls -l


            清除一個作業

            清除作業的命令格式為:
            代碼:

            atrm [job no] 或at -r [job no]

            要清除某個作業,首先要執行at -l命令,以獲取相應的作業標識,然后對該作業標識使用at -r 命令,清除該作業。
            代碼:

            $ at -l
            1? ? ? ?2004-11-02 10:40 a sam
            3? ? ? ?2004-11-02 15:00 a sam
            4? ? ? ?2004-11-01 19:07 a sam
            $at -r 3
            $at -l
            1? ? ? ?2004-11-02 10:40 a sam
            4? ? ? ?2004-11-01 19:07 a sam



            有些系統使用at-r [job no]命令清除作業。



            3.&

            當在前臺運行某個作業時,終端被該作業占據;而在后臺運行作業時,它不會占據終端。可以使用&命令把作業放到后臺執行。

            該命令的一般形式為:
            代碼:
            命令&



            在后臺運行作業時要當心:需要用戶交互的命令不要放在后臺執行,因為這樣你的機器就會在那里傻等。
            不過,作業在后臺運行一樣會將結果輸出到屏幕上,干擾你的工作。如果放在后臺運行的作業會產生大量的輸出,最好使用下面的方法把它的輸出重定向到某個文件中:
            代碼:

            command >out.file 2>&1 &


            在上面的例子中,2>&1表示所有的標準輸出和錯誤輸出都將被重定向到一個叫做out.file 的文件中。
            當你成功地提交進程以后,就會顯示出一個進程號,可以用它來監控該進程,或殺死它。

            例一:

            查找名為“httpd.conf”的文件,并把所有標準輸出和錯誤輸出重定向到f i n d . d t的文件中:
            代碼:

            # find /etc/httpd/ -name "httpd.conf" -print >find.dt 2>&1 &
            [2] 7832
            [1]? ?Done? ? ? ? ? ? ? ? ? ? find /etc/ -name "httpd.conf" -print >find.dt 2>&1 &

            成功提交該命令之后,系統給出了它的進程號7832。
            代碼:

            # cat find.dt
            /etc/httpd/conf/httpd.conf
            [2]+? Done? ? ? ? ? ? ? ? ? ? find /etc/httpd/ -name "httpd.conf" -print >find.dt 2>&1 &

            查看find.dt,可以看到執行結果


            例二:
            在后臺執行腳本,如:有一個叫psl的腳本
            代碼:

            $ps psl &
            [7878]

            用ps命令查看進程
            用提交命令時所得到的進程號來監控它的運行。用p s命令和g r e p命令列出這個進程:
            代碼:

            # ps -x |grep 7832
            7868 pts/0? ? S? ? ? 0:00 grep 7832


            如果系統不支持ps x命令,可以用:
            代碼:

            # ps -ef |grep 7832
            root? ? ? 7866? 7790? 0 23:40 pts/0? ? 00:00:00 grep 7832

            在用p s命令列出進程時,它無法確定該進程是運行在前臺還是后臺。


            殺死后臺進程

            殺死后臺進程可以使用k i l l命令。當一個進程被放到后臺運行時, s h e l l會給出一個進程號,我們可以根據這個進程號,用k i l l命令殺死該進程。該命令的基本形式為:
            代碼:

            kill -signal [process_number]


            現在暫且不要考慮其中的各種不同信號。
            在殺進程的時候,執行下面的命令(你的進程號可能會不同)并按回車鍵。系統將會給出相應的信息告訴用戶進程已經被殺死。
            代碼:

            $kill 7832


            如果系統沒有給出任何信息,告訴你進程已經被殺死,那么不妨等一會兒,也許系統正在殺該進程,如果還沒有回應,就再執行另外一個k i l l命令,這次帶上一個信號選項:
            代碼:

            $kill - 9 7868

            如果用上述方法提交了一個后臺進程,那么在退出時該進程將會被終止。為了使后臺進程能夠在退出后繼續運行,可以使用n o h u p命令。

            4.nohug

            如果你正在運行一個進程,而且你覺得在退出帳戶時該進程還不會結束,那么可以使用n o h u p命令。該命令可以在你退出帳戶之后繼續運行相應的進程。n o h u p就是不掛起的意思( no hang up)。
            該命令的一般形式為:
            代碼:

            nohup command &


            使用nohup命令提交作業
            如果使用n o h u p命令提交作業,那么在缺省情況下該作業的所有輸出都被重定向到一個名為n o h u p . o u t的文件中,除非另外指定了輸出文件:
            代碼:

            nohup command > myout.file 2>&1

            在上面的例子中,輸出被重定向到m y o u t . f i l e文件中。

            讓我們來看一個例子,驗證一下在退出帳戶后相應的作業是否能夠繼續運行。我們先提交一個名為p s 1的日志清除進程:
            代碼:

            $nobup ps1 &

            現在退出該s h e l l,再重新登錄,然后執行下面的命令:
            代碼:

            $ps x |grep ps1


            我們看到,該腳本還在運行。如果系統不支持ps x命令,使用ps -ef|grep ps1命令。

            5.一次提交幾個作業

            如果希望一次提交幾個命令,最好能夠把它們寫入到一個s h e l l腳本文件中,并用n o h u p命令來執行它。
            例如,下面的所有命令都用管道符號連接在一起;我們可以把這些命令存入一個文件,并使該文件可執行。
            代碼:

            cat /home/accounts/qrt_0499 | /apps/bin/trials.awk | sort | lp
            $cat > quarterend
            cat /home/accounts/qtr_0499 | /apps/bin/trials.awk | sort | lp
            <ctrl-D>


            現在讓它可執行:
            代碼:

            $ chmod 744 quarterend


            我們還將該腳本的所有輸出都重定向到一個名為q t r. o u t的文件中。
            代碼:

            nobup ./quarterend > qtr.out 2>


            后臺運行作業的:
            有時我們必須要對大文件進行大量更改,或執行一些復雜的查找,這些工作最好能夠在系統負荷較低時執行。
            創建一個定時清理日志文件或完成其他特殊工作的腳本,這樣只要提交一次,就可以每天晚上運行,而且無需你干預,只要看看相應的腳本日志就可以了。c r o n和其他工具可以使系統管理任務變得更輕松。



            6.*,?,[...],[!...]等


            ? 匹配文件名中的任何字符串。
            ? 匹配文件名中的單個字符。
            ? 匹配文件名中的字母或數字字符。


            下面就是這些特殊字符:

            * 匹配文件名中的任何字符串,包括空字符串。
            ? 匹配文件名中的任何單個字符。
            [...] 匹配[ ]中所包含的任何字符。
            [!...] 匹配[ ]中非感嘆號!之后的字符。


            當s h e l l遇到上述字符時,就會把它們當作特殊字符,而不是文件名中的普通字符,這樣用戶就可以用它們來匹配相應的文件名。

            a、*:使用星號*可以匹配文件名中的任何字符串。就不用多說了,和win下差不多
            b、?:使用可以匹配文件名中的任何單個字符。和win差不多
            c、[]:使用[ . . . ]可以用來匹配方括號[ ]中的任何字符。可以使用一個橫杠-來連接兩個字母或數字,以此來表示一個范圍。

            1)列出以i或o開頭的文件名:
            代碼:

            #ls [io]*


            2)列出log.開頭、后面跟隨一個數字、然后可以是任意字符串的文件名:
            代碼:

            #ls log.[0-9]*


            3)與例二相反,列出log.開頭、后面不跟隨一個數字、然后可以是任意字符串的文件名
            代碼:

            #ls log.[!0-9]*


            4)列出所有以LPS開頭、中間可以是任何兩個字符,最后以1結尾的文件名:
            代碼:

            #ls LPS??1


            5)列出所有以大寫字母開頭的文件名:
            代碼:

            $ ls [A-Z]*


            6)列出所有以小寫字母開頭的文件名:
            代碼:

            $ ls [a-z]*


            7)為了列出所有以數字開頭的文件名:
            代碼:

            $ ls [0-9]*


            8)列出所有以. 開頭的文件名(隱含文件,例如. p r o f i l e、. r h o s t s、. h i s t o r y等):
            代碼:

            $ ls .*


            Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1456841

            posted on 2007-08-09 00:55 旅途 閱讀(299) 評論(0)  編輯 收藏 引用 所屬分類: Linux Shell

            久久九九久精品国产免费直播| 久久精品这里热有精品| 伊人久久大香线焦综合四虎| 无码伊人66久久大杳蕉网站谷歌 | 91精品国产高清91久久久久久| 一本色道久久88综合日韩精品 | 国内精品人妻无码久久久影院导航| 久久成人永久免费播放| 久久久久无码国产精品不卡| 91久久精品国产免费直播| 国产ww久久久久久久久久| 青青草原综合久久| 久久久久噜噜噜亚洲熟女综合| 国产精品成人久久久久三级午夜电影 | 国产精品久久久福利| 久久国产免费观看精品| 国产激情久久久久影院老熟女免费 | 日韩十八禁一区二区久久| 日韩精品久久久久久久电影| 狠狠色丁香久久婷婷综合图片 | 国产成人精品久久亚洲高清不卡| 国产精品久久久天天影视香蕉| 久久性生大片免费观看性| 噜噜噜色噜噜噜久久| 色综合久久久久综合体桃花网| 狠色狠色狠狠色综合久久| 精品综合久久久久久88小说| 色综合久久夜色精品国产| 久久中文骚妇内射| 精品久久久无码中文字幕天天| 久久精品国产欧美日韩99热| 国产亚洲精品美女久久久| 日本精品久久久久影院日本| 日韩人妻无码精品久久久不卡| 日本三级久久网| 亚洲va国产va天堂va久久| 国产高潮久久免费观看| 午夜精品久久久久久中宇| 欧美性大战久久久久久 | 99久久无色码中文字幕| 中文精品99久久国产|