O script Bash funciona a partir do prompt, mas não do cron

3

Ao executar um script bash do cron, ele falha com o seguinte erro

/bin/sh: -c: line 0: unexpected EOF while looking for matching '''
/bin/sh: -c: line 1: syntax error: unexpected end of file

O estranho é que funciona perfeitamente quando executado a partir do prompt

Script inteiro

#!/bin/sh
NOW=$(date +"%b-%d-%y")
bu_PATH="/home/webserver/"

curtime=$(date)

echo ""
echo "Starting backup: $curtime"
echo ""
echo "Moving to $bu_PATH"
cd $bu_PATH

BACKUP_FILE="backup_$NOW.tgz"

echo ""
echo "The backup file will be called $BACKUP_FILE"

RUN_BACKUP="/usr/local/psa/bin/pleskbackup --server --output-file=$bu_PATH$BACKUP_FILE"

echo "Running backup...."
echo '$RUN_BACKUP'

curtime=$(date)

echo "Backup complete: $curtime"

echo ""

echo "Remove older than 7 days of files..."
ssh server '/shares/backup/webserver/cleanup.sh'

curtime=$(date)
echo ""

echo "Connecting to FTP: $curtime"

sftp -b server <<EOF
        cd /shares/backup/webserver/
        put $bu_PATH$BACKUP_FILE
        quit
EOF;

curtime=$(date)
echo "FTP Transfer Complete: $curtime"
echo ""
echo "Cleaning up Local backups"
sh /home/cleanup.sh
echo ""
echo "Clean up log files"
find /home/webserver/logs/*.log -mtime +7 -exec rm {} \;
echo "Job Complete"

Esta é a entrada do crontab

/home/backup.sh > /home/webserver/logs/BackupLog-'date +%m%d%y'.log

Obrigado Rob

    
por Rob 10.08.2011 / 12:17

2 respostas

8

Você precisa escapar os sinais% na entrada crontab se você usar backticks (') no crontab.

assim:

/home/backup.sh > /home/webserver/logs/BackupLog-'date +\%m\%d\%y'.log

Eles são tratados como nova linha, se você não escapar deles.

    
por 10.08.2011 / 12:40
3

Seu EOF parece errado, EOF; não corresponde ao seu esperado EOF (remova o ponto e vírgula).

[hlinden@dolphin tmp]$ cat dog.sh 
#!/bin/bash
cat <<EOF
dog
cat
EOF;
[hlinden@dolphin tmp]$ sh dog.sh 
dog.sh: line 6: warning: here-document at line 3 delimited by end-of-file (wanted 'EOF')
dog
cat
EOF;
[hlinden@dolphin tmp]$ sed -i s/\;// dog.sh 
[hlinden@dolphin tmp]$ sh dog.sh
dog
cat
[hlinden@dolphin tmp]$
    
por 10.08.2011 / 12:25