![Использовать локальную службу NTP](https://rvso.com/image/36015/%D0%98%D1%81%D0%BF%D0%BE%D0%BB%D1%8C%D0%B7%D0%BE%D0%B2%D0%B0%D1%82%D1%8C%20%D0%BB%D0%BE%D0%BA%D0%B0%D0%BB%D1%8C%D0%BD%D1%83%D1%8E%20%D1%81%D0%BB%D1%83%D0%B6%D0%B1%D1%83%20NTP.png)
Я пытаюсь заставить систему, не имеющую внешнего доступа к Интернету (A), получать время из другой системы в локальной сети, которая имеет его (B).
В ntp.conf А (весь файл внизу) я добавил:
server 192.168.2.102
restrict 192.168.2.102
Ссылаясь на IP B. После часа чтения страниц руководства, просмотра примеров в сети и т. д., насколько я могу судить, это должно означать, что он будет использовать этот локальный сервер и доверять ему во всем.
Однако это не работает. Я могу посмотреть два времени обмена в wireshark
, и работающие ntpq -p
на A шоу:
remote refid st t when poll reach delay offset jitter
==============================================================================
192.168.2.102 .INIT. 16 u 16 64 0 0.000 0.000 0.000
Если я остановлюсь ntpd
на A и попробую ntpd -gq
, я снова смогу наблюдать за обменом данными в Wireshark, но через минуту или две команда завершается с сообщением «Серверы не найдены».
Я даже попытался добавить в конф А:
fudge 192.168.2.102 stratum 1
Никакой разницы.
Как заставить ntpd установить время с определенного сервера? Похоже, раньше это было достаточно просто использовать ntpdate
, но теперь эта возможность устарела и отсутствует в системе.
Вот весь ntp.conf для машины A. Это стоковый Debian wheezy. Единственное, что я изменил, это добавил строки, включающие 192.168.2.102, и закомментировал серверы пула Debian, чтобы попытаться устранить путаницу, так что они в любом случае недоступны.
# /etc/ntp.conf, configuration for ntpd; see ntp.conf(5) for help
driftfile /var/lib/ntp/ntp.drift
# Enable this if you want statistics to be logged.
#statsdir /var/log/ntpstats/
statistics loopstats peerstats clockstats
filegen loopstats file loopstats type day enable
filegen peerstats file peerstats type day enable
filegen clockstats file clockstats type day enable
# You do need to talk to an NTP server or two (or three).
#server ntp.your-provider.example
server 192.168.2.102
restrict 192.168.2.102
fudge 192.168.2.102 stratum 1
# pool.ntp.org maps to about 1000 low-stratum NTP servers. Your server will
# pick a different set every time it starts up. Please consider joining the
# pool: <http://www.pool.ntp.org/join.html>
#server 0.debian.pool.ntp.org iburst
#server 1.debian.pool.ntp.org iburst
#server 2.debian.pool.ntp.org iburst
#server 3.debian.pool.ntp.org iburst
# Access control configuration; see /usr/share/doc/ntp-doc/html/accopt.html for
# details. The web page <http://support.ntp.org/bin/view/Support/AccessRestrictions>
# might also be helpful.
#
# Note that "restrict" applies to both servers and clients, so a configuration
# that might be intended to block requests from certain clients could also end
# up blocking replies from your own upstream servers.
# By default, exchange time with everybody, but don't allow configuration.
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
# Clients from this (example!) subnet have unlimited access, but only if
# cryptographically authenticated.
#restrict 192.168.123.0 mask 255.255.255.0 notrust
# If you want to provide time to your local subnet, change the next line.
# (Again, the address is an example only.)
#broadcast 192.168.123.255
# If you want to listen to time broadcasts on your local subnet, de-comment the
# next lines. Please do this only if you trust everybody on the network!
#disable auth
#broadcastclient
решение1
Должно сработать что-то вроде следующего.
restrict default ignore
restrict 127.0.0.1 nomodify
restrict 192.168.2.102 mask 255.255.255.0 nomodify notrap noquery
server 192.168.2.102 burst iburst
server 127.127.1.0
fudge 127.127.1.0 stratum 10
решение2
У меня это заработало, так что для потомков кто-то на #ntp
(freenode) сказал, что машина A может быть недовольна, если B не сообщает о себе как о синхронизированной. Это можно наблюдать, когда ntpq -p
на B не отображаются серверы с префиксом звездочка.
Подделка местного источникаБ(который на самом деле синхронизируется, путем проверки системных часов) исправил это:
server 127.127.1.0
fudge 127.127.1.0 stratum 10
Однако важнонетсделай это наАпоскольку он будет доверять страте 10 больше, чем тому, к чему он относит «локально синхронизированную» машину B.