shell後臺操作介紹

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

cron和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文件。

論壇例子
can't start cron file FIFO exist
http://www.chinaunix.net/forum/viewtopic.php?t=87026

15 1 * * * /opt/bin/ta.sh /opt/aadir > /dev/null 2>&1中2>&1的意思
http://www.chinaunix.net/forum/viewtopic.php?t=139356

編寫crontab:每週自動執行將一文件夾的內容備份,並且文件名字以生成的日期命名.
http://bbs.chinaunix.net/forum/viewtopic.php?t=263863

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腳本時,使用命令行方式。

命令行方式:

代碼:
at [-f script] [-m -l -r] [time] [date]



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

1、例一:提示符方式

代碼:
# 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



2、例二:命令行方式
如果希望向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運行。俺的機子時間不對。

3、還可以使用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]命令清除作業。

&命令

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

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



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

代碼:
command >out.file 2>&1 &



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

關於>&2、2>&1等重定向的詳細解釋!
http://bbs.chinaunix.net/forum/viewtopic.php?t=16361

例一:

查找名爲“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命令。


kill這段俺沒法驗證,到後看到再說

nohug命令

如果你正在運行一個進程,而且你覺得在退出帳戶時該進程還不會結束,那麼可以使用n o h u p命令。該命令可以在你退出帳戶之後繼續運行相應的進程。N o h u p就是不掛起的意思( n ohang 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命令。



一次提交幾個作業

如果希望一次提交幾個命令,最好能夠把它們寫入到一個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和其他工具可以使系統管理任務變得更輕鬆。

*,?,[...],[!...]

引用:
• 匹配文件名中的任何字符串。
• 匹配文件名中的單個字符。
• 匹配文件名中的字母或數字字符。


下面就是這些特殊字符:

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


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

1、*:使用星號*可以匹配文件名中的任何字符串。就不用多說了,和win下差不多
2、?:使用可以匹配文件名中的任何單個字符。和win差不多


3、[]:使用[ . . . ]可以用來匹配方括號[ ]中的任何字符。可以使用一個橫槓-來連接兩個字母或數字,以此來表示一個範圍。

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 .*







發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章