сценарий crontab, не работающий

Ниже мой job.sh Файл

echo 'Job Started Running'
echo 'password' | sudo  ./logstash -f /usr/share/logstash/bin/contact-index-logstash.conf
echo 'Job Ended'

Ниже мой sudo crontab -e

* * * * *  bash ~/job.sh > ~/log.log 2>&1

ниже мое состояние крона

>  service cron status ● cron.service - Regular background program

> processing daemon    Loaded: loaded (/lib/systemd/system/cron.service;

> enabled; vendor preset: enabled)    Active: active (running) since Thu
> 2017-11-09 22:09:03 IST; 1h 40min ago

>      Docs: man:cron(8)  Main PID: 869 (cron)

>     Tasks: 1    Memory: 12.3M

>       CPU: 1min 40.378s    CGroup: /system.slice/cron.service
>            └─869 /usr/sbin/cron -f

> 
> Nov 09 23:42:01 akshay CRON[6264]: pam_unix(cron:session): session
>opened for user root by (uid=0) Nov 09 23:43:01 akshay CRON[6270]:
> pam_unix(cron:session): session opened for user root by (uid=0) 

>Nov 09 23:43:01 akshay CRON[6271]: (root) CMD (bash ~/job.sh > ~/log.log
> 2>&1) 

Nov 09 23:43:01 akshay CRON[6270]: pam_unix(cron:session):
> session closed for user root Nov 09 23:44:01 akshay CRON[6293]:
> pam_unix(cron:session): session opened for user root by (uid=0) 
Nov 09
> 23:44:01 akshay CRON[6294]: (root) CMD (bash ~/job.sh > ~/log.log
> 2>&1)

Когда я выполняю sh файл непосредственно на оболочке, он работает без любой ошибки, но под crontab он не работает..

0
задан 9 November 2017 в 11:27

1 ответ

После предложений в комментарии @steeldriver вот то, как это должно быть.

Ваш job.sh файл (принятие logstash расположен в том же месте!):

echo 'Job Started Running'
./logstash -f /usr/share/logstash/bin/contact-index-logstash.conf
echo 'Job Ended'

Ваш корень crontab:

* * * * *  /home/username/job.sh > /home/username/log.log 2>&1

cron запускает Ваш скрипт с sh по умолчанию, таким образом, я удалил ненужное bash подоболочка – если Вам, тем не менее, нужен он просто, добавляет его снова.

1
ответ дан 1 November 2019 в 06:09

Другие вопросы по тегам:

Похожие вопросы: