自己在編寫crontab時(shí)遇到了一點(diǎn)坑,花了好久時(shí)間,所以記錄下來。
定時(shí)任務(wù)文件位置
/etc/crontab
注意事項(xiàng):
1.commands命令中,用到的路徑最好是全路徑噢!
2.最好將要執(zhí)行的定時(shí)任務(wù)放到一個(gè).sh文件中,然后在.sh文件的開頭添加以下代碼。
①首先在控制臺(tái)執(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í)任務(wù)的.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
為什么要加這些呢?
因?yàn)槟憧梢源蜷_/etc/crontab,查看到最上面的path的值
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
你可以發(fā)現(xiàn),crontab定時(shí)任務(wù)執(zhí)行時(shí)的PATH只有這么幾個(gè)目錄,而你的定時(shí)任務(wù)中,很有可能有一些指令,例如:adb,是不在path之內(nèi),所有如果直接執(zhí)行定時(shí)任務(wù),就會(huì)報(bào)錯(cuò)。因此,需要export PATH。(一種方式是直接修改etc/crontab文件中的PATH值;另一種是將定時(shí)任務(wù)放到腳本文件中,然后在文件的最上方export PATH = 。。。提倡后者噢)
如何查看定時(shí)任務(wù)出錯(cuò)報(bào)告呢?
1.重定向錯(cuò)誤信息到指定的文件(推薦)
*/1 * * * * root commond > /root/err.log 2>&1
這里的意思是將指令執(zhí)行的錯(cuò)誤信息,重定向到/root/err.log文件中。
2.啟動(dòng)cron.log文件
網(wǎng)上很多都是通過這種方式,但是,我發(fā)現(xiàn),通過這種方式是看不到具體的出錯(cuò)情況的,只會(huì)在出錯(cuò)的時(shí)候看到“NoMTAinstalled, discarding output”,個(gè)人覺得這種方式并沒有用,因?yàn)槟悴荒芏ㄎ荒愕降啄睦锍鲥e(cuò)了。唯一的用處是,可以看到crontab中文件是否變化,重新加載。如果還是想使用這種方式,介紹一下吧。默認(rèn)情況是沒有cron.log文件噢,需要通過一下操作。
1. 修改rsyslog
sudo vim /etc/rsyslog.d/50-default.conf
cron.* /var/log/cron.log #將cron前面的注釋符去掉
2.重啟rsyslog
sudo service rsyslog restar