shell脚本在由cronjob执行时失败,否则工作正常

时间:2013-06-03 05:10:45

标签: java linux shell cron executable-jar

我有一个可执行jar,我编写了一个shell脚本来执行它。当我手动运行shell脚本时,它运行正常但是当计划每周使用crontab运行它时,它会出现以下错误 -

log_process.sh: line 16: java: command not found

我的shell脚本中的第16行是 -

java -jar $jar_path $logDirectory $logNamePattern $processedLogDirectory $oldResultsDirectory 2>>$log_file 1>&2

任何想法为什么它会在我手动运行时运行正常而在vrontab作业运行时却没有运行?

1 个答案:

答案 0 :(得分:5)

您的cron作业无法访问您作为用户所拥有的相同$ PATH变量。

解决此问题的最简单方法是打开终端,然后运行此命令:

which java

这将为您提供java可执行文件的绝对路径。例如:

/opt/Oracle/Java/bin/java

用整个路径替换'java'命令。

您可能还想在shell脚本中指定JAVA_HOME变量。 从您的终端运行:

echo $JAVA_HOME

那会给你另一条路,比如'/ opt / Oracle / Java'。在您的脚本中(假设您正在使用bash),在运行java命令之前,请输入:

export JAVA_HOME=/opt/Oracle/Java

用前一个echo给你的输出替换'/ opt / Oracle / Java'。