Данная статья применима к:
- Astra Linux
В стандартные дистрибутивы и репозитории Astra Linux включены следующие службы точного времени:
- серверная служба NTP (ntpd) (пакетами ntp);
- серверная служба chrony (chronyd) (пакет chrony);
- серверная служба OpenNTP (openntpd) (пакет openntp);
- клиентская системная служба timedatectl / systemd-timesyncd.service.
Подробнее про эти службы можно прочитать в статье Службы синхронизации времени в Astra Linux. В статье также можно ознакомиться с базовыми терминами, связанными с организацией служб времени в компьютерах.
Начиная с обновлений Astra Linux Common Edition 2.12.10, Astra Linux Special Edition x.7 помимо указанных выше служб в репозиториях стал доступен пакет linuxptp, содержащий следующие службы:
- ptp4l - служба протокола времени высокой точности, реализующая работу по протоколу времени высокой точности PTP (Precision Time Protocol) в соответствии со стандартом IEEE 1588. Точность протокола зависит от того, как устанавливаются метки времени в пакетах IEEE 1588. При установке отметок времени программным путём, когда на точность влияют прерывания, загрузка процессора, и иные факторы, обеспечивается точность 1-100 микросекунд. Аппаратная поддержка обеспечивает точность до единиц микросекунд;
- phc2sys - служба синхронизации часов;
- timemaster - служба координации, обеспечивающая совместную работу традиционной службы времени ntp и службы времени высокой точности ptp.
Проверка оборудования
Пакет ориентирован на использование аппаратных средств точного времени, в частности, аппаратных возможностей сетевых карт (аппаратные отметки времени).
Пакет можно настроить и запустить и без сетевых карт, поддерживающих аппаратные возможности, что повлечет некоторое снижение точности. Настройка пакета для работы без аппаратной поддержки описана ниже.
Проверить, поддерживает ли сетевая карта аппаратные отметки времени можно из командной строки с помощью команды ethtool из пакета ethtool (пакет ethtool необходимо установить, если он не был установлен ранее):
sudo ethtool -T eth0
Установка пакета
Пакет linuxptp доступен в репозитории Astra Linux Common Edition начиная с версии 2.12.10 и может быть установлен с помощью графического менеджера пакетов (см. Графический менеджер пакетов synaptic) или из командной строки командой:
Настройка службы timemaster
Конфигурация службы timemaster находится в файле /etc/linuxptp/timemaster.conf.
Подробно возможные параметры настройки описаны в электронной справочной системе:
Включение службы домена точного времени (ptp_domain)
Для включения службы времени высокой точности ptp4l раскомментировать в файле настроек /etc/linuxptp/timemaster.conf секцию [ptp_domain 0] (в примере - настройка домена точного времени, использующего интерфейс eth0):
[ptp_domain 0]
interfaces eth0
delay 10e-6
Домен точного времени обслуживается сервисом ptp4l, настройка этого сервиса описана ниже.
Настройка работы со службой chronyd
Для включения работы со службой chronyd:
- Установить пакет chrony, если он не был ранее установлен.
Остановить службу chronyd и запретить её запуск:
sudo systemctl stop chronyd
sudo systemctl mask chronydВ файле настроек /etc/linuxptp/timemaster.conf:
Убедиться, что в секции [timemaster] параметр ntp_program имеет значение cronyd:
[timemaster] ntp_program chronyd
В секции [chrony.conf] указать значение параметра include равным /etc/chrony/chrony.conf:
[chrony.conf] include /etc/chrony/chrony.conf
Запустить (перезапустить) службу timemaster:
sudo systemctl restart timemaster
Настройка работы со службой ntp
Для включения работы со службой ntp:
- Установить пакет ntp, если он не был ранее установлен.
Остановить службу ntp и запретить её запуск:
sudo systemctl stop ntp
sudo systemctl mask ntpВ файле настроек /etc/linuxptp/timemaster.conf в секции [timemaster] значение параметра ntp_program нужно заменить на ntpd вместо cronyd:
[timemaster] ntp_program ntpd
Запустить (перезапустить) службу timemaster:
sudo systemctl restart timemaster
Настройка автоматического запуска timemaster
Кроме настройки конфигурационного файла нужно разрешить автоматический запуск службы timemaster при старте системы:
Настройка службы ptp4l
Служба ptp4l представляет собой реализацию протокола времени высокой точности и по умолчанию настроена на работу с сетевыми картами, поддерживающими аппаратные отметки времени (time stamping).
Как проверить наличие в сетевой карте аппаратной поддержки описано выше.
Конфигурация службы ptp4l хранится в файле /etc/linuxptp/ptp4l.conf, описание которого доступно в справочной системе:
Если используются сетевые карты без аппаратной поддержки отметок времени, то в конфигурации службы ptp4l (файл /etc/linuxptp/ptp4l.conf) нужно заменить аппаратную поддержку на программную:
time_stamping hardware
time_stamping software
Настройка службы phc2sys
Служба phc2sys настроек не требует, и если в системе имеется с чем синхронизировать системные часы RTC (имеется сетевая карта с аппаратными часами), phc2sys запустится автоматически с нужными параметрами. При работе с сетевыми картами, не поддерживающими аппаратные отметки времени служба phc2sys не запускается.
Запуск всех служб
После завершения настройки запуск всех служб осуществляется командой
Служба timemaster сама запустит запустит все остальные сервисы, в итоге статус нормально и полностью запущенной службы при наличии аппаратной поддержки выглядит примерно так: