小心別讓日子把你給混了

          光榮在于平淡...艱巨在于漫長...
          posts - 26, comments - 7, trackbacks - 0, articles - 1
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

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

          Posted on 2007-12-21 09:44 60 閱讀(447) 評論(0)  編輯  收藏
          本次主要講述后臺運行命令(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 .*


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 宁津县| 宣武区| 上栗县| 安塞县| 乃东县| 关岭| 延长县| 保山市| 共和县| 格尔木市| 靖州| 芦山县| 林州市| 山西省| 会东县| 阜南县| 潮州市| 盖州市| 资源县| 洛浦县| 鄂伦春自治旗| 溧阳市| 苍梧县| 马尔康县| 道真| 兰州市| 鄂尔多斯市| 新蔡县| 稻城县| 岳阳县| 潼南县| 道孚县| 双桥区| 信丰县| 霞浦县| 鲜城| 江安县| 即墨市| 双辽市| 神木县| 彭州市|