毎分cronジョブを実行する

Run Cron Job Every Minute



Linuxのバックグラウンドでプログラムまたはスクリプトを実行する場合は、cronジョブが非常に重要です。 cronジョブの助けを借りて、指定された時間間隔の後にバックグラウンドでプログラムまたはスクリプトを実行できます。

cronジョブの実際の例をいくつか見てみましょう。







  • たとえば、あなたがWebサイトを所有していて、Webサイトのすべてのユーザーに毎日電子メールを送信したいとします。あなたがしなければならないのは、電子メール送信スクリプトを書いて、そのスクリプトを毎日実行するためのcronジョブを設定することです。
  • たとえば、広告代理店を所有していて、残高が5ドル未満のすべての広告主に再請求するように通知したいとします。すべての広告主の残高を確認するスクリプトを作成するだけで、5ドルを下回ると、広告主の携帯電話番号またはメールに通知が送信されます。次に、5〜10分ごと、または1時間ごとにスクリプトを実行するようにcronジョブを設定します。

Linuxでのcronジョブの使用法は他にもたくさんあります。



この記事では、Linuxで毎分cronジョブを実行する方法を紹介します。デモンストレーションにはDebian9Stretchを使用します。ただし、任意の最新のLinuxディストリビューションを使用できます。始めましょう。



Linuxでは、 cronジョブを実行するため。 cronジョブは任意のユーザーとして実行できます。 Linuxのすべてのユーザーは、 crontab 独自のcronジョブのセットを実行するためのファイル。





デフォルトでは、ユーザーは crontab Linux上のファイル。あなたは作成することができます crontab 次のコマンドでファイルします。

$crontab-と



このコマンドを初めて実行する場合は、リストからテキストエディタを選択するように求められます。選びます ナノ 、デフォルトのもの。あなたが好きなものを選ぶことができます。完了したら、を押します

NS crontab ファイルを作成し(まだ利用できない場合)、お気に入りのテキストエディタで開く必要があります。これで、このファイルの最後に独自のcronジョブを追加できます。問題がなければ、保存してテキストエディタを終了します。

毎分コマンドを実行する構文:

の構文 crontab ファイルは次のとおりです。

分時dayOfMonth月dayOfWeekcommandToRun

ここ、

  • することができます 059
  • 時間 することもできます 059
  • dayOfMonth することができます 131
  • することができます 112
  • 曜日 することができます 0707 日曜日を意味し、 1 月曜日を意味し、 2 火曜日などを意味します。

を実行するには commandToRun 毎分コマンド、あなたはそれを書くべきです crontab 次のようにファイルします。

* * * * *commandToRun

毎分Crobジョブを実行する:

理論がわかったので、簡単なスクリプトを追加しましょう timer.shcrontab ファイルを作成し、その管理方法を確認してください。

の中に timer.sh スクリプト、次のコード行しかありません。新しいファイルを作成するだけです /home/shovon/bin/timer.log (まだ存在しない場合)そして、dateコマンドの出力をそれに追加します。

それでは、スクリプトを crontab 次の行で毎分実行します。

* * * * * //ショボン/午前/timer.sh

保存したら crontab ファイルを作成してテキストエディタを終了します。 crontab ファイルをインストールする必要があります。

1分が経過すると、新しいファイルは timer.log 以下のスクリーンショットのマークされたセクションでわかるように、は目的のディレクトリに作成されます。

から timer.log ログファイル、スクリプトが timer.sh 毎分実行されます。

cronジョブからのエラーのキャッチ:

cronジョブからのエラーをキャッチするには、エラーをに送信します。 エラーログ ファイルと通常の出力 access.log たとえばファイル。もちろん、ファイルには任意の名前を付けることができます。

これを示すために、スクリプトを変更しました timer.sh 若干。これで、エラーはに送信されます エラーログ のファイル /ホーム/ショボン/ビン ディレクトリと出力はに送信されます access.log の中に /ホーム/ショボン/ビン ディレクトリ。

最初は / tmp / i_must_be_here ファイルが存在しないため、エラーが発生します エラーログ あなたが見ることができるようにファイル。

NS access.log 現在、ファイルは空です。

次に、ファイルを作成します / tmp / i_must_be_here

ご覧のとおり、出力は access.log 今すぐファイルしてください。

必要に応じて、次のように同じファイル内の出力とエラーをリダイレクトできます。

ご覧のとおり、STDINおよびSTDERR出力は out.log ファイル。

ジョブを再度実行する前に、最後のジョブの実行が終了したことを確認します。

これを機能させるには、ジョブの開始直後に一時ファイルを作成し、ジョブが終了する直前にファイルを削除します。次に、ジョブを開始する前に、一時ファイルが存在するかどうかを確認できます。含まれている場合は、一時ファイルが使用できない場合にのみ、ジョブを終了してジョブを実行できます。

この単純なスクリプトはまさにそれを行います。

ご覧のとおり、 timer.pid ファイルが作成されます。

読む access.log ファイルは、前のcronジョブの実行が終了する前にcronジョブが実行されないことを証明します。ご覧のとおり、01:32:01に実行され、次回は01:33:01に実行されるはずでしたが、実行されませんでした。代わりに、約3分後の01:35:01に実行されました。

簡単なデバッグのためのcronジョブ出力の整理:

出力を適切にフォーマットして、cronジョブのデバッグを容易にすることができます。

それを行う方法の例を次のスクリプトに示します。

ご覧のとおり、出力、エラー、および成功メッセージはログファイルに適切に出力されます。

あなたはcronジョブとシェルスクリプトで驚くべきことをすることができます。ここでいくつかのアイデアを示しました。しかし、空はあなたの限界です。あなたが持っているアイデアを自由に試してみてください。この記事を読んでくれてありがとう。