本次主要講述后臺運行命令(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文件,相應的命令為:
可以像使用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文件
如果不小心誤刪了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 >是用戶名。如果由于權限問題無法完成拷貝,可以用:
其中,< 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命令查看進程
用提交命令時所得到的進程號來監控它的運行。用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]
|
現在暫且不要考慮其中的各種不同信號。
在殺進程的時候,執行下面的命令(你的進程號可能會不同)并按回車鍵。系統將會給出相應的信息告訴用戶進程已經被殺死。
如果系統沒有給出任何信息,告訴你進程已經被殺死,那么不妨等一會兒,也許系統正在殺該進程,如果還沒有回應,就再執行另外一個k i l l命令,這次帶上一個信號選項:
如果用上述方法提交了一個后臺進程,那么在退出時該進程將會被終止。為了使后臺進程能夠在退出后繼續運行,可以使用n o h u p命令。
4.nohug
如果你正在運行一個進程,而且你覺得在退出帳戶時該進程還不會結束,那么可以使用n o h u p命令。該命令可以在你退出帳戶之后繼續運行相應的進程。n o h u p就是不掛起的意思( no hang up)。
該命令的一般形式為:
使用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的日志清除進程:
現在退出該s h e l l,再重新登錄,然后執行下面的命令:
我們看到,該腳本還在運行。如果系統不支持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開頭的文件名:
2)列出log.開頭、后面跟隨一個數字、然后可以是任意字符串的文件名:
3)與例二相反,列出log.開頭、后面不跟隨一個數字、然后可以是任意字符串的文件名
4)列出所有以LPS開頭、中間可以是任何兩個字符,最后以1結尾的文件名:
5)列出所有以大寫字母開頭的文件名:
6)列出所有以小寫字母開頭的文件名:
7)為了列出所有以數字開頭的文件名:
8)列出所有以. 開頭的文件名(隱含文件,例如. p r o f i l e、. r h o s t s、. h i s t o r y等):
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1456841