NTP - ローカルホストのタイムアウト - ソースネットワークは lo ではなく eth0 を使用します

NTP - ローカルホストのタイムアウト - ソースネットワークは lo ではなく eth0 を使用します

Centos 6 サーバーで ntpq -p コマンドがタイムアウトになります。

# ntpq -pn
127.0.0.1: timed out, nothing received
***Request timed out

tcpdump の結果によると、ループバック インターフェイスではなく eth0 が使用されています。

14:42:11.392517 IP 10.122.5.2.45969 > 127.0.0.1.ntp: NTPv2, Reserved, length 12
14:42:16.397594 IP 10.122.5.2.45969 > 127.0.0.1.ntp: NTPv2, Reserved, length 12
14:42:29.528535 IP 10.122.5.2.35338 > 127.0.0.1.ntp: NTPv2, Reserved, length 12

ネットワーク構成に何か問題があるようです。でも、どこでしょうか?

私の ntp.conf の内容。

# cat /etc/ntp.conf
tinker panic 0

driftfile /var/lib/ntp/drift

server x.x.x.x iburst
server x.x.x.x iburst


# By default, exchange time with everybody, but don't allow configuration.
# See /usr/share/doc/ntp-doc/html/accopt.html for details.
restrict -4 default kod notrap nomodify nopeer noquery
restrict -6 default kod notrap nomodify nopeer noquery

# Local users may interrogate the ntp server more closely.
restrict 127.0.0.1
restrict ::1

keys /etc/ntp/keys

答え1

問題は、iptables nat ルールの誤りが原因でした。

Chain POSTROUTING (policy ACCEPT)
target     prot opt source               destination
MASQUERADE  all  --  0.0.0.0/0            0.0.0.0/0

宛先を本来の IP に変更すると、ntp が動作し始めました。

Chain POSTROUTING (policy ACCEPT)
target     prot opt source               destination
MASQUERADE  all  --  0.0.0.0/0            x.x.x.x

関連情報