天天看點

linux 定時執行shell腳本

在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

繼續閱讀