現在、crontabを介してシェルスクリプトを実行しようとしています。うまくいかず、ここで何が間違っているのかわかりません。
私がやりたいことは、定期的にnodejsでjavascript(index.js)ファイルを実行することです。
ファイルはのrun-logger.sh
実行可能ファイル(-rwxr-xr-x
)です/home/pi/apps/fritz-client
。
run-logger.sh
:
#!/bin/bash
# execute index.js and save all output to log
/usr/bin/env node /home/pi/apps/fritz-client/index.js >> fritz.log
このコマンドをスタンドアロンで実行すると、/usr/bin/env node /home/pi/apps/fritz-client/index.js >> fritz.log
すべてがうまく機能します!私がやってもcd /home/pi/apps/fritz-client && ./run-logger.sh
crontab -e
:
#
# lots of comments
#
*/1 * * * * /home/pi/apps/fritz-client/run-logger.sh
crontab -l
表示されます。
私は試した:
*/1 * * * * /home/pi/apps/fritz-client/run-logger.sh
*/1 * * * * /bin/bash /home/pi/apps/fritz-client/run-logger.sh
*/1 * * * * /bin/sh /home/pi/apps/fritz-client/run-logger.sh
*/1 * * * * bash /home/pi/apps/fritz-client/run-logger.sh
このコマンドの結果はmore /proc/version
次のとおりです。
Linux version 4.1.18-v7+ (dc4@dc4-XPS13-9333) (gcc version 4.9.3 (crosstool-NG crosstool-ng-1.22.0-88-g8460611) ) #846 SMP Thu Feb 25 14:22:53 GMT 2016
修正する
今回はLinuxとRaspberry Piを使った最初の週です。だから忍耐を持ってください:)
syslog output
Mar 14 21:08:01 raspberrypi CRON[3609]: (pi) CMD (/home/pi/apps/fritz-client/run-logger.sh)
Mar 14 21:08:01 raspberrypi CRON[3602]: (CRON) info (No MTA installed, discarding output)
Mar 14 21:09:01 raspberrypi CRON[3626]: (pi) CMD (/home/pi/apps/fritz-client/run-logger.sh)
Mar 14 21:09:01 raspberrypi CRON[3619]: (CRON) info (No MTA installed, discarding output)
Mar 14 21:10:01 raspberrypi rsyslogd-2007: action 'action 17' suspended, next retry is Mon Mar 14 21:11:31 2016 [try http://www.rsyslog.com/e/2007 ]
Mar 14 21:10:01 raspberrypi CRON[3642]: (pi) CMD (/home/pi/apps/fritz-client/run-logger.sh)
Mar 14 21:10:01 raspberrypi CRON[3635]: (CRON) info (No MTA installed, discarding output)
Mar 14 21:10:06 raspberrypi crontab[3651]: (pi) BEGIN EDIT (pi)
Mar 14 21:10:19 raspberrypi crontab[3651]: (pi) REPLACE (pi)
Mar 14 21:10:19 raspberrypi crontab[3651]: (pi) END EDIT (pi)
ps aux | grep cron
root 382 0.0 0.2 5548 2452 ? Ss 19:01 0:00 /usr/sbin/cron -f
pi 3683 0.0 0.2 4772 1936 pts/0 S+ 21:11 0:00 grep --color=auto cron
ベストアンサー1
これを使用しないでください。/usr/bin/env
実行可能ファイルを検索するだけで十分です。実行可能ファイルのフルパスを指定します。node
/bin
/usr/bin/
node
または、crontabでPATHを拡張することもできます。
PATH=$PATH:/usr/local/bin
など。