自己在編寫crontab時遇到了一點坑,花了好久時間,所以記錄下來。
定時任務文件位置
/etc/crontab
注意事項:
1.commands命令中,用到的路徑最好是全路徑噢!
2.最好將要執行的定時任務放到一個.sh文件中,然后在.sh文件的開頭添加以下代碼。
①首先在控制臺執行$PATH,以下是我的結果
bash: /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/usr/lib/jvm/java-8-oracle/bin:/usr/lib/jvm/java-8-oracle/db/bin:/usr/lib/jvm/java-8-oracle/jre/bin:/usr/local/software/android-sdk/tools:/usr/local/software/android-sdk/platform-tools:/usr/local/software/nodejs/node-v6.11.0-linux-x64/bin
②然后打開你用來存放定時任務的.sh文件,在開頭添加
#!/bin/bash
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/usr/lib/jvm/java-8-oracle/bin:/usr/lib/jvm/java-8-oracle/db/bin:/usr/lib/jvm/java-8-oracle/jre/bin:/usr/local/software/android-sdk/tools:/usr/local/software/android-sdk/platform-tools:/usr/local/software/nodejs/node-v6.11.0-linux-x64/bin
為什么要加這些呢?
因為你可以打開/etc/crontab,查看到最上面的path的值
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
你可以發現,crontab定時任務執行時的PATH只有這么幾個目錄,而你的定時任務中,很有可能有一些指令,例如:adb,是不在path之內,所有如果直接執行定時任務,就會報錯。因此,需要export PATH。(一種方式是直接修改etc/crontab文件中的PATH值;另一種是將定時任務放到腳本文件中,然后在文件的最上方export PATH = 。。。提倡后者噢)
如何查看定時任務出錯報告呢?
1.重定向錯誤信息到指定的文件(推薦)
*/1 * * * * root commond > /root/err.log 2>&1
這里的意思是將指令執行的錯誤信息,重定向到/root/err.log文件中。
2.啟動cron.log文件
網上很多都是通過這種方式,但是,我發現,通過這種方式是看不到具體的出錯情況的,只會在出錯的時候看到“NoMTAinstalled, discarding output”,個人覺得這種方式并沒有用,因為你不能定位你到底哪里出錯了。唯一的用處是,可以看到crontab中文件是否變化,重新加載。如果還是想使用這種方式,介紹一下吧。默認情況是沒有cron.log文件噢,需要通過一下操作。
1. 修改rsyslog
sudo vim /etc/rsyslog.d/50-default.conf
cron.* /var/log/cron.log #將cron前面的注釋符去掉
2.重啟rsyslog
sudo service rsyslog restar