手动可以执行脚本,crontab执行失败,可能和环境变量有关(如果涉及到环境变量)

1 发现问题
一个shell脚本手动执行没有问题,但是配置到crontab中失效,报错环境变量找不到。

2 分析问题
查看用户环境变量~/.bash_profile、系统环境变量/etc/profile发现环境变量存在,比较费解。

3 解决问题
在.sh脚本中加入source /etc/profile或者source ~/.bash_profile引入环境变量即可解决。

4 其他注意点
4.1 新创建的cron job不会立刻执行,至少要过2分钟才执行。若重启cron则立刻执行。

4.2 每条job执行完毕后,系统会自动将输出发送邮件给当前系统用户。日积月累甚至会撑爆整个系统。所以每条job命令后面进行重定向处理是非常必要的 >/dev/null 2>&1 。前提是对job中命令需要正常输出已经作了一定处理, 比如追加到某个特定日志文件。

4.3 当crontab突然失效时,可尝试service crond restart解决问题。或者查看日志看某个job有没有执行/报错tail -f /var/log/cron。

4.4 不要随意运行crontab -r。它从crontab目录(/var/spool/cron)中删除用户crontab文件。删除了该用户的所有crontab都没了。

4.5 在crontab中%是有特殊含义的,表示换行的意思。必须进行转义%。如date ‘+%Y%m%d’ 是不会执行的,应该换成date ‘+%Y%m%d’。

原文:https://blog.csdn.net/woshixuye/article/details/53043472

猜你喜欢

转载自blog.csdn.net/asd54090/article/details/88641818