共计 718 个字符,预计需要花费 2 分钟才能阅读完成。
最近一段在检查服务器的定时脚本的时候发现了有部分服务器上的 mysqldump 定时脚本并没有被执行,因为在脚本中有生成日志所以就发现了问题。于是先去 /var/log/cron 中查看了下日志发现在相应的时候 crond 有执行相应的脚本, 初步分析是是脚本的逻辑有问题于是就去看了下,并且执行了下发现脚本的逻辑是没有问题的,而且直接执行是没有问题的,后来又去 /etc/crontab 文件里去看了下
发现 crontab 中的环境变量不一样,但是脚本中有使用绝对路径,最后发现 mysqldump 中有使用 allow-keywords 参数,估计是调用系统参数, 于是先看了下系统的环境变量先 echo 看下
[root@localhost 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
…略…
这样再跟踪了一次发现定时脚本执行正常, 最后不得不说很多调用系统的参数或者是使用系统环境变量下的文件最好要添加上系统环境变量。
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-02/140237.htm