在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" 中有錯誤,您可以這樣來進行調試:
這将執行該腳本并顯示所有變量的值。
shell還有一個不需要執行腳本隻是檢查文法的模式。可以這樣使用:
這将傳回所有文法錯誤。
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/[email protected] @"test.sql"
sql腳本檔案:test.sql
insert into test_tb values (sysdate);
crontab檔案:
0,15,30,45 * * * * /apps/bin/test.sh