使用crontab执行脚本会返回127错误代码

时间:2009-11-27 08:50:55

标签: unix exit crontab

我手动在UNIX系统上手动执行脚本,它在ORACLE数据库中成功运行并更新了所需的记录。然而,当我用crontab执行相同的脚本时,我的进程退出时出现错误代码127。

进一步分析后,我发现这些陈述存在一些问题。


LOGFILE =萨钦 ORALOGIN = ABC / ABC @ ABCD

cmd ='sqlplus $ {ORALOGIN}< SQLS>> $ {SVC_HOME} / LOGFILES / $ {LOGFILE} date +%Y-%m-%d“;

eval $ cmd

请建议解决方案

2 个答案:

答案 0 :(得分:1)

当cron执行脚本时,您确定${ORALOGIN}${LOGFILE}是有效的ENV变量吗?

有时为用户工作的脚本不适用于cron,因为cron执行没有用户拥有的所有ENV变量。

答案 1 :(得分:0)

在互动环境中做

env | grep ORACLE

自从我使用sqlplus以来很长一段时间,但我记得它需要一些环境变量才能运行(ORACLE_HOME?)而且我怀疑你的cron作业环境没有这些设置。