Presented by DMZ. (非武装エリア)
最終更新日: 2021年11月7日
(This site is not official.)

Topに戻る

NTPサーバーの稼働確認

Zabbixサーバー側からリモートホストのNTPサーバーの状況を確認するには、ntpdateコマンドを使った方法で確認できます。
通常、シェルコマンドでリモートホストへntpdateコマンドを実行する場合は次のコマンドを実行します。

# ntpdate -q -t 1 -o 4 <NTPサーバのIP> ; ret=$?
# echo $ret

このコマンドが正常に実行されると、現在の時刻がNTPサーバーから返されると共に実行結果のステータスとして ret に 0 が返されます。 また失敗した場合には ret の値は 0 以外になります。このコマンドをZabbixにて定期的に実行することで、NTPサーバーが正常に動作しているかを検知できるようにします。
Zabbixサーバーからリモートホストへのコマンド実行するには、コマンドをスクリプトとして作成して特定のフォルダーに保存しておく必要があります。 デフォルトでスクリプトを置くフォルダーは次のコマンドで確認できます。

# zabbix_server --help | grep ExternalScripts
ExternalScripts "/etc/zabbix/externalscripts"

以下の手順で作成するスクリプトをこのフォルダーに置いてください。 また、フォルダーの場所をデフォルトから別の場所に変更したい時には /etc/zabbix/zabbix_server.conf ファイルでExternalScriptsを指定してください。
  1. /etc/zabbix/externalscripts/check_ntpdate.sh の作成
/etc/zabbix/externalscriptsフォルダーが存在しない場合には、先にフォルダーを作成します。

# mkdir /etc/zabbix/externalscripts

チェック用スクリプトを作成します。
(/etc/zabbix/externalscripts/check_ntpdate.sh)

#!/bin/bash
# -------------------------------------------------
# This command is NTP service available check.
# use: check_nslookup.sh $1
# $1 --- ntp server ip address. (NTPサーバーのIP)
#
# Return: =0(Nomal) / !=0(Fail)
# -------------------------------------------------
/usr/sbin/ntpdate -p 1 -q -t 1 -o 4 -u 33123 $1 > /dev/null 2>&1 ;ret=$?
echo $ret

作成したスクリプトに実行権限を与えます。 なお、上記スクリプトで"-u 33123"としているのは、デフォルトではntpdateコマンドが送信元ポート番号として123を使うため、Zabbixサーバー自身でNTPサーバーを動作させていた場合にはこのポートがNTPサーバーで使われてしまいntpdateコマンドが実行できないため、明示的に送信ポートを変更している。 NTPサーバーが実行されていない環境であればこのオプションは不要です。

# chmod +x /etc/zabbix/externalscripts/check_ntpdate.sh

作成したシェルスクリプトを試してみましょう。

# /etc/zabbix/externalscripts/check_ntpdate.sh <NTP-Server-IP>

<NTP-Server-IP>の部分にNTPサーバーのIPアドレスを指定して実行した場合、正常に応答があった場合は 0 が返り、そうでない場合には 0 以外の値は返ってきます。


■ 監視アイテム作成

[設定] - [ホスト] から監視対象のサーバを選び、設定画面の [アイテム]タブを開き [アイテムの作成] をクリックします。
次のようなアイテムを作成します。
以上を設定したら保存前に[テスト]を実行して値がとれているか確認します。
[値の取得とテスト]を実行すると、"値"のフィールドに実行した結果の値が表示されます。 
これが問題なければ、[追加]をクリックして内容を保存します。


■ トリガーの作成

作成したアイテムによって、定期的にNTPのチェックがされてるようになったなら、この値が変動した時に実行されるトリガーを作っていきます。[トリガー]タブを開き [トリガーの作成] をクリックします。
(1) まず、NTPサーバーに障害が発生したと判断するトリガーを作成します。
条件式として判定に使うアイテムと、その判定基準を定義します。 ここでは"DNS query check"というアイテムが0以外だった場合に障害と判定します。
条件式を指定できたら、[追加]をクリックしてトリガーを登録します。 以上で、NTPサーバーに問題がある場合にこのトリガーが"重度の障害"として発生されます。


以上で、NTPの監視設定は完了です。 これで、NTPサービスに障害が発生して何も応答が得られない時には、Zabbixは重度の障害として報告するようになります。


Topに戻る