crontab的定時任務會報錯:command not found,手動執行腳本能成功。php
1.crontab與環境變量shell
cron並不知道所須要的特殊環境變量。因此要保證在shelll腳本中提供全部必要的路徑和環境變量,除了一些自動設置的全局變量。注意以下3點:bash
1)腳本中涉及文件路徑時寫全局路徑;rest
2)腳本執行要用到程序或其餘環境變量時,經過source命令引入環境變量,如:日誌
#!/bin/bash
source /etc/profile
/usr/local/php/bin/php think sitespeedcode
或者在root的crontab文件中加入:crontab
3)當手動執行腳本OK,可是crontab不執行時。是環境變量問題,能夠在crontab中直接引入環境變量解決。如:
0 * * * * /etc/profile;/bin/bash /home/scripts/test.sh >/dev/null 2>&1ip
2.其餘應該注意的問題it
1)新建立的cron job,不會立刻執行,至少要過2分鐘才執行。若是重啓cron則立刻執行。
2)每條 JOB 執行完畢以後,系統會自動將輸出發送郵件給當前系統用戶。日積月累,很是的多,甚至會撐爆整個系統。因此每條 JOB 命令後面進行重定向處理是很是必要的: >/dev/null 2>&1 。前提是對 Job 中的命令須要正常輸出已經做了必定的處理, 好比追加到某個特定日誌文件。
3)當crontab忽然失效時,能夠嘗試/etc/init.d/crond restart解決問題。或者查看日誌看某個job有沒有執行/報錯tail -f /var/log/cron。
4)別亂運行crontab -r。它從Crontab目錄(/var/spool/cron)中刪除用戶的Crontab文件。刪除了該用戶的全部crontab都沒了。
5)在crontab中%是有特殊含義的,表示換行的意思。若是要用的話必須進行轉義\%,如常常用的date `+%Y%m%d`在crontab裏是不會執行的,應該換成date `+\%Y\%m\%d`。class
3.crontab中的輸出配置
crontab中常常配置運行腳本輸出爲:>/dev/null 2>&1,來避免crontab運行中有內容輸出。
shell命令的結果能夠經過 '>' 的形式來定義輸出
/dev/null 表明空設備文件
> 表明重定向到哪裏,例如:echo "123" > /home/123.txt
1 表示stdout標準輸出,系統默認值是1,因此">/dev/null"等同於"1>/dev/null"
2 表示stderr標準錯誤
& 表示等同於的意思,2>&1,表示2的輸出重定向等同於1
重定向輸出語句的含義:
1>/dev/null 首先表示標準輸出重定向到空設備文件,就是不輸出任何信息到終端,不顯示任何信息。
2>&1 表示標準錯誤輸出重定向等同於標準輸出,由於以前標準輸出已經重定向到了空設備文件,因此標準錯誤輸出也重定向到空設備文件。