Cronjobが正しく実行されていません。

Cronjobが正しく実行されていません。

このshスクリプトがあります。

ufw allow 27017 && iptables -F

test.shファイルから

次のようにルートのcronjobを使用して毎日07:00に実行したいと思います。

0 7 * * * /root/cron/test.sh

また、このスクリプトが実際にgrep CRON /var/log/syslogを使用して実行されていることを確認し、実行されていることがわかります。

8月24日 07:00:01 vps118774 CRON[1672]: (ルート) CMD (/root/cron/test.sh)

私の問題は、test.shの実際のスクリプトが適切なcronjobを使用して実行されているポートのロックを解除するために正しく実行されないことです。要点は、次のようにサーバーの端末でスクリプトを手動で実行することです。

sh script.sh

すべてがうまく機能し、スクリプトが必要なタスクを実行するので、スクリプトは期待どおりに実行されますが、cronの実行に問題はありますか?

実行ログを入れたところ、次のような結果が出ました。

root/cron/test.sh: 2: /root/cron/test.sh: ufw: 見つかりません

答え1

Cronジョブは、通常の対話型シェル環境とは異なるシェル環境で実行されます。たとえば、このPATH変数にはさまざまなディレクトリのリストを含めることができ、ユーティリティの実行に慣れているいくつかのディレクトリが欠落している可能性があります。

ufwユーティリティがどこにあるかを調べてcommand -v ufwから(コマンドラインで使用)

  1. スクリプトでユーティリティのフルパスを使用するか、
  2. ユーティリティ(および)を見つけることができるディレクトリをPATH含むようにスクリプト内の変数を変更します。ufwiptables

質問が示すように、スクリプトに正しい#!- 行がありません。明示的に実行しても問題はありませんが、shcronジョブ仕様ではそうしません。代わりにスクリプトを実行可能にし、次のように記述します。

#!/bin/sh

PATH="$PATH:/usr/sbin:/sbin"

ufw allow 27017 && iptables -F

次に、今のようにcrontabでスクリプトを呼び出します。

ここでは、スクリプトでこれを行う方法を示すために、/usr/sbin2つのディレクトリと変数も追加/sbinしました。PATH

関連情報