Задание Cron: если условия / else не работают должным образом, если сценарий оболочки запускается из задания Cron - PullRequest
0 голосов
/ 22 декабря 2011

Я написал следующий скрипт:

#!/bin/bash 

MAIL=/usr/mail/${LOGNAME:?}

. /installations/etl_scripts/etl_job.properties 

JOB_LOG_FILE_PATH=$JOB_LOG_FILE_PATH
export JOB_LOG_FILE_PATH

JOB_LOG_FILE_NAME=$JOB_LOG_FILE_NAME
export JOB_LOG_FILE_NAME

JAVA_HOME=$JAVA_HOME
export JAVA_HOME

CATALINA_HOME=$CATALINA_HOME
export CATALINA_HOME

PENTAHO_HOME=$PENTAHO_HOME
export PENTAHO_HOME

PENTAHO_JAVA_HOME=$PENTAHO_JAVA_HOME
export PENTAHO_JAVA_HOME

ETL_JOB_HOME=$ETL_JOB_HOME
export ETL_JOB_HOME

ETL_SCRIPTS_HOME=$ETL_SCRIPTS_HOME
export ETL_SCRIPTS_HOME

PATH=$PATH
export PATH

# Virre ETL transformation job execution
echo $ETL_JOB_ENABLED >> /tmp/templog.log
date +"%D %r `echo Scheduled Pentaho ETL job is starting...`" >> $JOB_LOG_FILE_PATH/$JOB_LOG_FILE_NAME
if [ $ETL_JOB_ENABLED = 'Yes' ]; then
    sh $PENTAHO_HOME/kitchen.sh -file $ETL_JOB_HOME/sync_job.kjb >> $JOB_LOG_FILE_PATH/$JOB_LOG_FILE_NAME
else
    echo "Pentaho ETL job is dissabled. Please enable it in etl_job.properties by setting ETL_JOB_ENABLED property to yes" >> $JOB_LOG_FILE_PATH/$JOB_LOG_FILE_NAME
fi
date +"%D %r `echo Completed`" >> $JOB_LOG_FILE_PATH/$JOB_LOG_FILE_NAME
echo ----------------------------------------------------------------- >> $JOB_LOG_FILE_PATH/$JOB_LOG_FILE_NAME

Когда я запускаю его из консоли, операторы if / else работают как положено. Но когда он был запущен из запланированного задания Cron, он зависает где-то внутри или до оператора if: он успешно записывает сообщение до оператора if в файл журнала и после этого ничего не происходит.

Какие-нибудь решения, как решить эту проблему?

1 Ответ

1 голос
/ 22 декабря 2011

Вы можете попробовать удалить расширение для файла kitchen.sh, а также добавить полный путь к sh:

/bin/sh $PENTAHO_HOME/kitchen -file $ETL_JOB_HOME/sync_job.kjb >> $JOB_LOG_FILE_PATH/$JOB_LOG_FILE_NAME
...