crontab 各參數詳解及如何查看日志記錄


詳見:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt145

crontab各參數說明:

 

crontab [-u user] [file] 

crontab [-u user] [-e|-l|-r] 

crontab -l -u root 查看root用戶的任務表

注意crontab是分用戶的,以誰登錄就會編輯到誰的crontab

 

-e : 執行文字編輯器來編輯crontab,內定的文字編輯器是VI
-r : 刪除目前的crontab
-l : 列出目前的crontab(查看專用)
-i : 會和-r 配合使用,在刪除當前的crontab時詢問,輸入y 則刪除

/etc/init.d/crond restart(stop/start)重啟或者停止后再啟動

 

備份命令:

應用:對crontab進行備份crontab -l>/home/backup/crontab/crontab`date '+%Y%m%d'`.bak

22 21 * * * /usr/bin/backup

 

crontab 中文亂碼

crontab啟動的任務沒有獲取系統的環境變量,導致中文亂碼

解決辦法:

   在執行的腳步中添加編碼方式或者添加對應的環境變量

如:

1、/usr/bin/java -Dfile.encoding=UTF-8 -jar ALDTool.jar

2、在腳本開頭增加:

export LANG="en_US.UTF-8"


crontab特殊的符號說明:
"*"代表所有的取值范圍內的數字。特別要注意哦!
"/"代表每的意思,如"*/5"表示每5個單位
"-"代表從某個數字到某個數字
","分散的數字
crontab文件的使用示例:

30 21 * * *    表示每晚的21:30 
45 4 1,10,22 * * 表示每月1、10、22日的4 : 45
10 1 * * 6,0 表示每周六、周日的1 : 10
0,30 18-23 * * * 表示在每天18 : 00至23 : 00之間每隔30分鍾
0 23 * * 6 表示每星期六的11 : 00 pm
* */1 * * * 每一小時
* 23-7/1 * * * 晚上11點到早上7點之間,每隔一小時
* 8,13 * * 1-5 從周一到周五的上午8點和下午1點
0 11 4 * mon-wed 每月的4號與每周一到周三的11點
0 4 1 jan * 一月一號的4點

 

-------------------------------- 如何查看crontab的日志記錄 --------------------------------------------------------

昨天crontab中的同步任務沒有執行,不知道是什么原因沒有執行,貌似任務hang住了,想查詢一下crontab到底問題出在哪里,或者hang在了什么地方。
如:30 12 * * * /data/bk/bk.sh >/tmp/test.log 2>&1 &

將crontab運行日志輸出到/tmp/test.log中


1.  linux
看 /var/log/cron這個文件就可以,可以用tail -f /var/log/cron觀察
 
2.  unix
在 /var/spool/cron/tmp文件中,有croutXXX001864的tmp文件,tail 這些文件就可以看到正在執行的任務了。
 
3. mail任務
在 /var/spool/mail/root 文件中,有crontab執行日志的記錄,用tail -f /var/spool/mail/root 即可查看最近的crontab執行情況。

=====================================================================================

yum install crontabs

rpm -q crontabs

ll /var/spool/cron == crontab -l

 

=====================================================================================

2.2 Crontab 格式說明

我們可以用crontab -e 添加要執行的命令。 命令執行的結果,無論是標准輸出還是錯誤輸出,都將以郵件形式發給用戶。

添加的命令必須以如下格式:

* * * * * /command path

前五個字段可以取整數值,指定何時開始工作,第六個域是字符串,即命令字段,其中包括了crontab調度執行的命令。 各個字段之間用spaces和tabs分割。

前5個字段分別表示:

分鍾:0-59

小時:1-23

日期:1-31

月份:1-12

星期:0-6(0表示周日)

還可以用一些特殊符號:

*: 表示任何時刻

,: 表示分割

-:表示一個段,如第二端里: 1-5,就表示1到5點

/n : 表示每個n的單位執行一次,如第二段里,*/1, 就表示每隔1個小時執行一次命令。也可以寫成1-23/1.

一些示例:

00 8,12,16 * * * /data/app/scripts/monitor/df.sh

30 2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh

10 8,12,16 * * * /data/app/scripts/monitor/check_ind_unusable.sh

10 8,12,16 * * * /data/app/scripts/monitor/check_maxfilesize.sh

10 8,12,16 * * * /data/app/scripts/monitor/check_objectsize.sh

43 21 * * * 21:43 執行

15 05 * * *    05:15 執行

0 17 * * * 17:00 執行

0 17 * * 1 每周一的 17:00 執行

0,10 17 * * 0,2,3 每周日,周二,周三的 17:00和 17:10 執行

0-10 17 1 * * 毎月1日從 17:00到7:10 毎隔1分鍾 執行

0 0 1,15 * 1 毎月1日和 15日和 一日的 0:00 執行

42 4 1 * *     毎月1日的 4:42分 執行

0 21 * * 1-6   周一到周六 21:00 執行

0,10,20,30,40,50 * * * * 每隔10分 執行

*/10 * * * *        每隔10分 執行

* 1 * * *         從1:0到1:59 每隔1分鍾 執行

0 1 * * *         1:00 執行

0 */1 * * *        毎時0分 每隔1小時 執行

0 * * * *         毎時0分 每隔1小時 執行

2 8-20/3 * * *      8:02,11:02,14:02,17:02,20:02 執行

30 5 1,15 * *       1日 和 15日的 5:30 執行

2.3 & 后台執行命令

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

如:

30 2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh &

在后台運行作業時要當心:需要用戶交互的命令不要放在后台執行,因為這樣你的機器就會在那里傻等。

不過,作業在后台運行一樣會將結果輸出到屏幕上,干擾你的工作。如果放在后台運行的作業會產生大量的輸出,最好使用下面的方法把它的輸出重定向到某個文件中:

如:
command >out.file 2>&1 &

在這個例子中,2>&1表示所有的標准輸出和錯誤輸出都將被重定向到一個叫做out.file 的文件中。

2.4 2>&1 含義

先看一個例子:

0 2 * * * /u01/test.sh >/dev/null 2>&1 &

這句話的意思就是在后台執行這條命令,並將錯誤輸出2重定向到標准輸出1,然后將標准輸出1全部放到/dev/null 文件,也就是清空。

在這里有有幾個數字的意思:

0表示鍵盤輸入

1表示標准輸出

2表示錯誤輸出.

我們也可以這樣寫:

0 2 * * * /u01/test.sh >/u01/out.file & –這里沒寫,默認是1

0 2 * * * /u01/test.sh 1>/u01/out.file &

0 2 * * * /u01/test.sh 2>/u01/out.file &

0 2 * * * /u01/test.sh 2>/u01/out.file 2>&1 &

將tesh.sh 命令輸出重定向到out.file, 即輸出內容不打印到屏幕上,而是輸出到out.file文件中。

2>&1 是將錯誤輸出重定向到標准輸出。 然后將標准輸入重定向到文件out.file。

&1 表示的是文件描述1,表示標准輸出,如果這里少了&就成了數字1,就表示重定向到文件1。

& :后台執行

測試:

ls 2>1 : 不會報沒有2文件的錯誤,但會輸出一個空的文件1;

ls xxx 2>1: 沒有xxx這個文件的錯誤輸出到了1中;

ls xxx 2>&1: 不會生成1這個文件了,不過錯誤跑到標准輸出了;

ls xxx >out.txt 2>&1 == ls xxx 1>out.txt 2>&1; 因為重定向符號>默認是1,這句就把錯誤輸出和標准輸出都傳到out.txt 文件中。

2.5 2>&1寫在后面的原因

格式:command > file 2>&1 == command 1> file 2>&1

首先是command > file將標准輸出重定向到file中, 2>&1 是標准錯誤拷貝了標准輸出,也就是同樣被重定向到file中,最終結果就是標准輸出和錯誤都被重定向到file中。

如果改成: command 2>&1 >file

2>&1 標准錯誤拷貝了標准輸出的行為,但此時標准輸出還是在終端。>file 后輸出才被重定向到file,但標准錯誤仍然保持在終端。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM