定時任務的完成contab

采用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

原創文章,作者:sjfbjs,如若轉載,請注明出處:http://www.www58058.com/31808

(0)
sjfbjssjfbjs
上一篇 2016-08-11 09:38
下一篇 2016-08-11 09:38

相關推薦

  • SSH會話劫持實現端口轉發

    在進行滲透測試時,我們有時候會碰到搭建的測試環境、產品服務器、DMZ或者其他類似的機器群的情況,這時我們完全可以把它們看作跳板。這些系統被設計成對外交互的接口,這時候我們考慮對其他域里的用戶進行SSH會話劫持是個不錯的選擇。 那么如果你擁有了某一個跳板的控制權限,想要通過另一個域的用戶對遠程域進行訪問會怎么辦呢?當然,這時候你是沒有密碼、密鑰的,你不能拋棄二…

    系統運維 2015-03-23
  • 利用keepalived實現主/從和主/主模式的高性能負載均衡集群

    要求: 1、使用nginx的反向代理功能實現負載均衡 2、keepalived實現高可用 ???????第一組的虛擬地址為172.16.1.100 ????????????D設備的優先級高 ???????第二組的虛擬地址為172.16.1.110 ????????????E設備的優先級高 3、分別實現主/從和主/主兩種配置 集群拓撲: ? ? ? 第一種:主…

    2017-06-25
  • 磁盤管理和文件系統

    磁盤結構 設備文件:關聯至一個設備驅動程序,進而能夠跟與之對應硬件設備進行通信 一切皆文件:open(), read(), write(), close() 設備類型: 塊設備:block,存取單位“塊”,磁盤 字符設備:char,存取單位“字符”,鍵盤 設備號碼: 主設備號:major number, 標識設備類型 次設備號:minor number, 標…

    Linux干貨 2017-04-23
  • Linux的用戶組和權限(一)

    導讀:本章主要內容如下       1.解釋Linux的安全模型      2.解釋用戶賬號和組群賬號的目的      3.用戶和組管理命令      4.理解并設置文件權限 &n…

    Linux干貨 2016-08-04
  • 編譯安裝httpd-2.4.9及新特性詳解

    前言 前面我們講解了httpd在CentOS6上(httpd-2.2)的相關功能配置,而CentOS7上采用了httpd-2.4的版本,那么httpd-2.4增加了哪些特性呢?接下來讓我們在CentOS6.6上手動編譯安裝一下httpd-2.4.9,看一下和httpd-2.2有什么不同,順便補充說一下httpd的其它功能。 環境及新特性介紹 環境介紹 系統環…

    Linux干貨 2015-04-15
  • 用戶和組及批量創建

    用戶和組       操作系統都有用戶和組,windows,linux等等,用戶和組用來做什么呢?       用戶,是我們進入系統時的憑證,不是每一個人想進就進的。你想吧,如果操作系統沒有用戶就能登錄進系統,那這就帶來了許許多多的安全隱患了。而組則是為了方便管理用戶的一個組容器。 &nb…

    系統運維 2016-08-04
欧美性久久久久