crontab中添加定时脚本不生效的原因

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了crontab中添加定时脚本不生效的原因相关的知识,希望对你有一定的参考价值。

   最近一段在检查服务器的定时脚本的时候发现了有部分服务器上的mysqldump定时脚本并没有被执行,因为在脚本中有生成日志所以就发现了问题。于是先去/var/log/cron中查看了下日志发现在相应的时候crond有执行相应的脚本,初步分析是是脚本的逻辑有问题于是就去看了下,并且执行了下发现脚本的逻辑是没有问题的,而且直接执行是没有问题的,后来又去/etc/crontab文件里去看了下技术分享

发现crontab中的环境变量不一样,但是脚本中有使用绝对路径,最后发现mysqldump中有使用allow-keywords参数,估计是调用系统参数,于是先看了下系统的环境变量先echo看下

[[email protected] etc]# echo $PATH
/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/mysql/bin:/root/bin

,就在mysqldump定时脚本中添加了这2行,添加系统中的环境变量

PATH=/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/mysql/bin:/root/bin
export $PATH
…略…

这样再跟踪了一次发现定时脚本执行正常,最后不得不说很多调用系统的参数或者是使用系统环境变量下的文件最好要添加上系统环境变量

本文出自 “技术随笔” 博客,谢绝转载!

以上是关于crontab中添加定时脚本不生效的原因的主要内容,如果未能解决你的问题,请参考以下文章

Centos7 crontab 环境变量不生效

crontab定时任务不执行的原因及查看任务执行情况

Crontab定时任务中python3脚本无法运行问题解决

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

docker-compose备份数据库命令,在crontab定时任务中不生效问题,解决方法

crontab添加了定时任务却无法执行