脚本手动执行正常,放cron中执行有问题的原因

Posted 运维的自我修养

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了脚本手动执行正常,放cron中执行有问题的原因相关的知识,希望对你有一定的参考价值。

问题原因:
  1. crond服务没启动
  2. 环境变量如 PATH LANG SHELL 等设置不对
  3. 脚本中引用的文件地址是相对路径,而非绝对路径.
 
排查步骤:  以 check.sh 为例
先检查cron日志中是否有脚本的执行记录:  grep check.sh /var/log/cron*
--> 没有执行的记录,则crond服务没启动. 检查crond服务状态: service crond status
--> 有执行记录,则crond服务运行正常. 脚本至少是执行过了.
  
清理掉/var/spool/clientmqueue/下的文件. 然后修改crontab让脚本1分钟后执行.
待执行完毕后查看新产生的文件,可以看到脚本执行的报错以及X-Cron-Env环境变量.
根据相应的报错来调整脚本的代码.
 
最好在写脚本的时候在脚本开头定义 PATH LANG 等脚本正常运行所需的环境变量.脚本中要使用到的文件或命令,也最好使用全路径而非相对路径.

以上是关于脚本手动执行正常,放cron中执行有问题的原因的主要内容,如果未能解决你的问题,请参考以下文章

cron 作业会杀死最后一个 cron 执行吗?

Bash 脚本未在 Cron 中正确执行

小记---------手动执行脚本正常执行,使用crontab定时执行时 不执行

linux 定时执行php脚本,脚本已在执行,但是无结果,手动执行有结果

crontab 无法执行

shell 脚本手动执行能成功,但是放在定时任务执行不成功