轉自:http://blog.csdn.net/jingxiangren/article/details/4745631
在oracle 中可以利用dbms_job包定時執行pl/sql、sql過程,在像備份等需要在作業系統級定時任務只能採用crontab來完成
本文講述crontab具體用法,以供備忘.
在oracle 中可以利用dbms_job包定時執行pl/sql、sql過程,在像備份等需要在作業系統級定時任務只能採用crontab來完成
利用crontab來定時執行任務大致有如下三步:
1、編寫shell指令碼
2、利用crontab加入到定時任務隊列
3、查看作業完成情況
一、如何建立shell指令碼
Linux下有很多不同的shell,但我們通常使用bash(bourne again shell)進行編程,因為bash是免費的並且很容易使用
程式必須以下面的行開始(必須方在檔案的第一行):
#! /bin/sh
符號#!用來告訴系統它後面的參數是用來執行該檔案的程式。在這個例子中我們使用/bin/sh來執行程式。
當編輯好指令碼時,要想執行指令碼,必須使指令碼可以執行
下面的命令,可以使指令碼可以執行
chmod +x filename
然後可以輸入./filename來執行指令碼。
註:在shell編程時,#符號表示注釋,只該行結束為止。在編寫程式時,最好使用注釋。
變數
shell下所有變數都以字串表示,變數不需要聲明,直接使用。直接對變數進行賦值
A="hello world"
取出變數用$符號,如:
#! /bin/sh
A="hello world"
echo "A is:"
echo $A
執行該指令碼輸出結果如下:
A is :
hello world
shell 命令和流程式控制制
1)unix命令
在shell中可以使用任意的unix命令,但這裡介紹一些更常用的unix命令
echo ''this is a example" :列印輸出到螢幕
ls:列出檔案清單
cp sourcefile destinationfile :拷貝檔案
2)概念:管道,重新導向和backtick
這些不是系統命令,但他們經常使用,很重要的
管道 | 將一個命令的輸出作為另外一個命令的輸入
grep -qa compat | more
重新導向:將命令的結果輸出到檔案,而不是標準輸出(螢幕)
〉寫入檔案並覆蓋舊檔案
〉〉輸出追加到檔案的尾部,保留舊檔案。
3)流程式控制制
if ... ; then
...
else if ...;then
...
else
...
fi
通常情況下,可以通過測試命令來對條件進行測試,比如可以比較字串,判斷檔案是否存在及是否有執行許可權等等
通常用“ [ ] “來表示條件測試,注意這裡空格很重要,要確保方括弧空格
[ -f "somefile" ] :判斷是否是一個檔案
[ -x "/bin/ls" ] :判斷/bin/ls是否存在並有可執行許可權
[ -n "$var" ] :判斷$var變數是否有值
[ "$a" = "$b" ] :判斷$a和$b是否相等
執行個體 一般編程步驟
任何優秀的指令碼都應該有協助和輸入參數,並且寫一個偽指令碼framework.sh,該指令碼包含了大多數指令碼都需要的架構結構。
是個非常不錯的注意。這時候,我們編寫指令碼時只需要執行cp命令即可
cp framework.sh myscript
然後插入自己需要的函數就可以了
調試
最簡單的調試命令當然是使用echo命令。您可以使用echo在任何懷疑出錯的地方列印任何變數值。這也是絕大多數的shell程式員要花費80%的時間來偵錯工具的原因。Shell程式的好處在於不需要重新編譯,插入一個echo命令也不需要多少時間。
shell也有一個真實的偵錯模式。如果在指令碼"strangescript" 中有錯誤,您可以這樣來進行調試:
sh -x strangescript
這將執行該指令碼並顯示所有變數的值。
shell還有一個不需要執行指令碼只是檢查文法的模式。可以這樣使用:
sh -n your_script
這將返回所有語法錯誤。
Redhat linux AS 3 下定時執行任務
二、cron調度進程
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檔案。
3.1.1 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列要啟動並執行命令
crontab的範例格式:
下面是c r o n t a b的格式:
分< >時< >日< >月< >星期< >要啟動並執行命令
其中< >表示空格。
C r o n t a b檔案的一個條目是從左邊讀起的,第一列是分,最後一列是要啟動並執行命令,它位
於星期的後面。
在這些域中,可以用橫杠-來表示一個時間範圍,例如你希望星期一至星期五運行某個作
業,那麼可以在星期域使用1 - 5來表示。還可以在這些域中使用逗號“,”,例如你希望星期一
和星期四運行某個作業,只需要使用1 , 4來表示。可以用星號*來表示連續的時間段。如果你
對某個表示時間的域沒有特別的限定,也應該在該域填入*。該檔案的每一個條目必須含有5
個時間域,而且每個域之間要用空格分隔。該檔案中所有的注釋行要在行首用#來表示。
crontab條目舉例
這裡有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 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檔案。9 9 %的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 >是使用者名稱,例如, j a m e s c r o n。在該檔案中加入如下的內容。
#。。。。這裡是解釋的話
0,15,30,45 18-06 * * * /bin/echo 'time'>/dev/console
儲存並退出。確信前面5個域用空格分隔。
在上面的例子中,系統將每隔1 5分鐘向控制台輸出一次目前時間。如果系統崩潰或掛起,
從最後所顯示的時間就可以一眼看出系統是什麼時間停止工作的。在有些系統中,用t t y 1來表
示控制台,可以根據實際情況對上面的例子進行相應的修改。
為了提交你剛剛建立的c r o n t a b檔案,可以把這個新建立的檔案作為c r o n命令的參數:
$ crontab jamescron
現在該檔案已經提交給c r o n進程,它將每隔1 5分鐘運行一次。
同時,新建立檔案的一個副本已經被放在/ v a r / s p o o l / c r o n目錄中,檔案名稱就是使用者名稱(即,
james)。
列出crontab檔案:
為了列出c r o n t a b檔案,可以用:
你將會看到和上面類似的內容。可以使用這種方法在$ 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會對其進行必要的完整性檢查。如果其中的某個域出現了超出允許範圍的值,它會提示你。
儲存並退出。最好在c r o n t a b檔案的每一個條目之上加入一條注釋,這樣就可以知道
它的功能、已耗用時間,更為重要的是,知道這是哪位使用者的作業。
可以使用前面講過的crontab -l命令列出它的全部資訊
為了刪除c r o n t a b檔案,可以用:
$ crontab -r
三,可以利用重新導向命令來輸出運行結果
> ,>>
四、具體執行個體
sh指令檔:test.sh
#! /bin/sh
su - oracle << EOF
sqlplus test/test@test @"test.sql"
sql指令檔:test.sql
insert into test_tb values (sysdate);
crontab檔案:
0,15,30,45 * * * * /apps/bin/test.sh
針對昨天幫忙解決的一道題目為例吧,記錄一下:
題目內容為:就是寫一個指令碼 ,後台定時每天淩晨2點執行並記錄一次vmstat 1 5 的資訊
分析:vmstat為記錄虛擬記憶體的使用方式,1 5的意思是每隔1s記錄一次,一共記錄5次的意思。
現在我們就需要寫一個指令碼來完成這個功能。
按照上面的所講的東西,我們的步驟如下:
(1)建立一個名為< u s e r > c r o n的檔案,其中< u s e r >是使用者名稱,例如, j a m e s c r o n。在該檔案中加入如下的內容。
00 2 * * * /usr/bin/vmstat 1 5 >> /home/liujiali/cin/liujiali(PS:首先我們需要確定vmstat命令的路徑,因為在這個指令碼中我們是無法擷取環境變數的。第二點是我採集的資料並未存入資料庫,而是存到了一個文字檔中,此處簡化了許多)
(2)提交你剛剛建立的c r o n t a b檔案,可以把這個新建立的檔案作為c r o n命令的參數:
$ crontab jamescron
(3)若是想要停止的話,則需要執行:
$ crontab -r