web-dev-qa-db-ja.com

monit-「成功した場合はそれ以外の場合はexec」

スクリプトの実行に問題があります成功した場合

~/.monitrc

check Host example.com with address example.com
if failed url http://example.com/startpage and content == "mainBaner"
timeout 10 seconds
then exec "/usr/local/bin/monit_example_error.sh"
    else if succeeded then exec "/usr/local/bin/monit_example_ok.sh"

エラーがある場合はスクリプトを実行しているように見えますが、エラーがない場合は実行されません。

ログは、テストが実行されて成功したことを示しています、/var/log/monit.log

[CEST Jun  8 12:24:52] debug    : 'example.com' succeeded testing protocol [HTTP] at INET[example.com:80/startpage] via TCP
[CEST Jun  8 12:25:22] debug    : 'example.com' succeeded connecting to INET[example.com:80/dlibra] via TCP
[CEST Jun  8 12:25:46] debug    : HTTP: Regular expression matches
[CEST Jun  8 12:25:46] debug    : 'example.com' succeeded testing protocol [HTTP] at INET[example.com:80/startpage] via TCP
[CEST Jun  8 12:26:16] debug    : 'example.com' succeeded connecting to INET[example.com:80/dlibra] via TCP
[CEST Jun  8 12:26:39] debug    : HTTP: Regular expression matches

/usr/local/bin/monit_example_ok.shの実行が期待どおりに機能することを確認しました(関連するディレクトリに関連するステータスファイルを作成します)。

OS:

% lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description:    Ubuntu 14.04.5 LTS
Release:    14.04
Codename:   trusty

% uname -a
Linux ql 3.13.0-119-generic #166-Ubuntu SMP Wed May 3 12:18:55 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux

Monit:

ii  monit                                1:5.6-2                                    AMD64        utility for monitoring and managing daemons or similar progra
2
LetMeSOThat4U

Succeedアクションは、failイベントが解決された後にのみ実行されます(つまり、状態failから状態success)に移行しますが、期待どおりに動作する場合ではありません。

3
DevOps