NTPDを使用してLinuxコンピュータの時刻を指定されたNTPサーバーに更新しようとしています。
シナリオは次のとおりです。
Linuxシステムが起動するたびにNTPサーバーの時間を更新したいと思います。成功しない場合は、成功するまで5分ごとに再試行したいと思います。(最大2時間)
検索した結果、NTPDを使用し、次のコマンドを使用する必要があることがわかりました。
#ntpdate ntp.server.com
(NTPDを開始する前)
#ntpd some_options_to_start
問題は次のとおりです。
- このコマンドが時間を正常に更新したかどうかはどうすればわかりますか?
- ntpdで時間更新間隔を設定できますか? (それともシェルで
sleep
and loopdo
../ のようなwhile
ものを使うべきですかfor
?)
上記のコマンドをシェルスクリプトで実行し、シェルをWebサーバーに配置したいと思います。これにより、クライアント(Webブラウザを使用)はWebサイトでスクリプトを実行します。したがって、(ネットワーク経由で)クライアントに結果を送信して、更新が成功したことを確認する必要があります。
ベストアンサー1
監視にスクリプトを使用するntpd
ことは一般的ではありません。デーモンは一般nagios
的に。munin
このツールは、問題が発生した場合に警告を送信できます。munin
オフセットが15msを超える場合は、Eメールを送信します。
通常、サーバーの1つが失敗した場合は、デーモンがサーバー間で選択できるように奇数のサーバーを使用する必要があります。通常3つで十分で、5つ以上であれば多すぎます。内部サーバーを監視する場合は、内部ネットワーク上のクライアントがそれを使用できる必要があります。合法的なサーバー、ISP NTP、またはDNSサーバーをクロックソースとして使用してください。パブリックプールとパブリックサーバーがあります。
ntpd
これは自己調整機能なので、一度設定して起動したら調整する必要はありません。最近の実装では日付の初期設定を実行するため、ntpd
すべてを使用する必要はありません。ntpdate
次のスクリプトは、ntpd出力のオフセットを解析し、オフセットが多すぎると報告します。問題が発生した場合は、cronで実行すると電子メールが送信されます。スクリプトはデフォルトで0.1秒オフセットで警告します。
#!/bin/bash
limit=100 # Set your limit in milliseconds here
offsets=$(ntpq -nc peers | tail -n +3 | cut -c 62-66 | tr -d '-')
for offset in ${offsets}; do
if [ ${offset:-0} -ge ${limit:-100} ]; then
echo "An NTPD offset is excessive - Please investigate"
exit 1
fi
done
# EOF