如果确认已经在脚本中用了绝对路径,这就可能是crontab的环境变量和自己运行时的环境变量不同导致。所以,
在shell脚本中加入
1)source /etc/profile
2)然后用locate /bin/hive找出对应一个hive的位置,当然由于向下兼容,当然找的是最新版本的hive的位置,将原本的hive命令改成绝对路径
简而言之,就是所有能用到绝对路径的地方都使用绝对路径,然后用的版本尽可能地高。
同时,为了方便问题的查找,在配置crontab的时候,尽量用【2>&1】的方式,以便能查找出问题所在。
[hadoop@emr-worker-8 sdk-dataproc]$ crontab -l
0 6 * * * sh /home/hadoop/sdk-dataproc/sdk-ctl.sh >>/home/hadoop/sdk-dataproc/corn-err.txt 2>&1

本文介绍了解决crontab环境下脚本运行失败的方法,包括通过设置环境变量、使用绝对路径引用命令以及配置错误日志来定位问题的具体步骤。
1075

被折叠的 条评论
为什么被折叠?



