1

У меня есть простой скрипт для запуска rclone. Он выполняется правильно из корневой командной строки. Он также выполняется правильно при вызове обычным заданием cron. Права доступа к сценарию установлены как root/root 0755, т.е. он исполняемый. (Так же и Rclone.)

Следующая строка - это задание incron, установленное incrontab -e и подтвержденное с помощью icrontab -l

/var/vhosts/localdir IN_ALL_EVENTS /bin/rclonescript.sh

Ниже приведен мой скрипт, который запускается из командной строки или из обычного задания cron:

#!/bin/bash
/usr/sbin/rclone copy /var/vhosts/localdir mygoogledrive:uploadfolder

Вот вывод из tail -f /var/log/cron:

Mar 16 18:45:55 localhost incrond[8215]: (root) CMD (/bin/rclonescript.sh)

Вывод выглядит нормально, но скрипт не запускается.

Вот как выглядит журнал cron, когда скрипт успешно вызывается из задания cron * * * * * /bin/rclonescript.sh:

Mar 16 18:59:01 localhost CROND[9070]: (root) CMD (/bin/rclonescript.sh)

Журнал практически такой же, но работа cron работает. Incron нет.

Я попытался установить путь в моем скрипте, сначала проверив:

[root@localhost ~]# echo $PATH
/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

... затем добавьте путь к сценарию следующим образом:

#!/bin/bash
Path=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin   
/usr/sbin/rclone copy /var/vhosts/localdir mygoogledrive:uploadfolder

Когда я пытаюсь сделать это как некую работу:

/var/vhosts/anne_scan IN_ALL_EVENTS,IN_NO_LOOP /bin bash rclonescript.sh

или же

/var/vhosts/anne_scan IN_ALL_EVENTS,IN_NO_LOOP /bin rclonescript.sh

Это приводит к отказу в разрешении:

Mar 17 09:00:27 localhost incrond[24917]: cannot exec process: Permission denied

1 ответ1

1

Добавьте sudo перед командой, вот так:

/var/vhosts/watcheddir IN_ALL_EVENTS,IN_NO_LOOP sudo /bin/sh /bin/yourscript.sh

Выберите пользователя следующим образом:

/var/vhosts/watcheddir IN_ALL_EVENTS,IN_NO_LOOP sudo -u username /bin/sh /bin/yourscript.sh

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