自己在編寫crontab時遇到了一點坑,花了好久時間,所以記錄下來外遇。
定時任務文件位置
/etc/crontab
注意事項:
1.commands命令中藏雏,用到的路徑最好是全路徑噢蘸朋!
2.最好將要執(zhí)行的定時任務放到一個.sh文件中克饶,然后在.sh文件的開頭添加以下代碼同诫。
①首先在控制臺執(zhí)行$PATH先口,以下是我的結(jié)果
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
你可以發(fā)現(xiàn)猴伶,crontab定時任務執(zhí)行時的PATH只有這么幾個目錄课舍,而你的定時任務中,很有可能有一些指令蜗顽,例如:adb布卡,是不在path之內(nèi),所有如果直接執(zhí)行定時任務雇盖,就會報錯忿等。因此,需要export PATH崔挖。(一種方式是直接修改etc/crontab文件中的PATH值贸街;另一種是將定時任務放到腳本文件中,然后在文件的最上方export PATH = 狸相。薛匪。。提倡后者噢)
如何查看定時任務出錯報告呢脓鹃?
1.重定向錯誤信息到指定的文件(推薦)
*/1 * * * * root commond > /root/err.log 2>&1
這里的意思是將指令執(zhí)行的錯誤信息逸尖,重定向到/root/err.log文件中。
2.啟動cron.log文件
網(wǎng)上很多都是通過這種方式瘸右,但是娇跟,我發(fā)現(xiàn),通過這種方式是看不到具體的出錯情況的太颤,只會在出錯的時候看到“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