$ crontab -l
#
# m h  dom mon dow   command

SHELL=/bin/bash

* * * * * (/usr/bin/curl -s -XPOST http://internal.ip -H 'Content-type: application/json' -d 'data')

$ ls -l /usr/bin/curl
-rwxr-xr-x 1 root root 123336 Jan 29  2012 /usr/bin/curl

$ uname -a
Linux machine 2.6.32-5-amd64 #1 SMP Mon Jan 16 16:22:28 UTC 2012 x86_64 GNU/Linux

$ cat /etc/debian_version
6.0.4

Но команда не выполняется, и я вижу следующее в /var/log/syslog:

Nov 29 20:29:01 machine /USR/SBIN/CRON[28580]: (CRON) error (grandchild #28582 failed with exit status 1)

Точно такая же команда при запуске напрямую из терминала работает нормально:

$ (/usr/bin/curl -s -XPOST http://internal.ip -H 'Content-type: application/json' -d 'data')
{}

Я попробовал поискать в Google, но все, что я смог найти, это то, что командный путь должен работать (да, я установил абсолютный путь) и что в конце crontab должна быть новая строка (есть). Есть идеи?

1 ответ1

1

вы не должны иметь SHELL =/bin/bash в выводе crontab -l.
бежать

crontab -e

и удалите SHELL =/bin/bash из crontab.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .