我需要启动一个特定的服务后,系统时钟正确的步进。
系统时间由时间同步(chronyd (chrony) version 3.5 (+CMDMON +NTP +REFCLOCK +RTC -PRIVDROP -SCFILTER -SIGND +ASYNCDNS -SECHASH +IPV6 -DEBUG)
)维护。
时间设置(如果相关的话)是:
server 192.168.100.1 trust minpoll 2 maxpoll 4 polltarget 30
refclock PPS /dev/pps0 refid KPPS trust lock GNSS maxdispersion 3 poll 2
refclock SOCK /var/run/chrony.sock refid GNSS maxdispersion 0.2 noselect
makestep 0.1 -1
driftfile /var/lib/chrony/drift
rtcsync
“正常跟踪状态”的示例是:
/ # chronyc tracking
Reference ID : C0A86401 (192.168.100.1)
Stratum : 2
Ref time (UTC) : Wed Dec 01 11:52:08 2021
System time : 0.000004254 seconds fast of NTP time
Last offset : +0.000000371 seconds
RMS offset : 0.000011254 seconds
Frequency : 17.761 ppm fast
Residual freq : +0.001 ppm
Skew : 0.185 ppm
Root delay : 0.000536977 seconds
Root dispersion : 0.000051758 seconds
Update interval : 16.2 seconds
Leap status : Normal
而“不同步”(初始)状态是:
/ # chronyc tracking
Reference ID : 00000000 ()
Stratum : 0
Ref time (UTC) : Thu Jan 01 00:00:00 1970
System time : 0.000000000 seconds fast of NTP time
Last offset : +0.000000000 seconds
RMS offset : 0.000000000 seconds
Frequency : 0.000 ppm slow
Residual freq : +0.000 ppm
Skew : 0.000 ppm
Root delay : 1.000000000 seconds
Root dispersion : 1.000000000 seconds
Update interval : 0.0 seconds
Leap status : Not synchronised
我似乎记得,无论何时层级更改,crony都可以调用脚本,但我找不到引用。
在任何情况下:是否有任何方法指示crony运行脚本/程序,或者在获得/丢失有效服务器跟踪时发送一些信号?
我目前所依赖的是一个相当丑陋的东西:while chronyc tracking | grep -q "Not synchronised"; do sleep 1; done
,但最好是由chronyd
来发出积极的信号。
详细信息:
chronyc tracking
和解析状态,但这并不是很好。发布于 2022-04-23 11:08:16
我也想做同样的事,却空手而归。
然而,我确实找到了chronyc waitsync
,这似乎是进行轮询的内置方式,而不需要显式地解析和睡眠。这对于我的情况来说已经足够好了,因为我只需要延迟一个启动操作。
该命令的存在还暗示(尽管无法证明)直接触发可能不受支持。如果触发是一个困难的要求,rsyslogd
能 帮助。
顺便说一句,一个人只能欣赏系统爱好者的热情,即使他们的答案显然是完全不相关的,也能传播他们的爱。
显然,目标系统不使用systemd
。问题是关于chronyd
,而不是关于systemd-timesyncd
,而systemd-time-wait-sync.service
只适用于后者。
https://stackoverflow.com/questions/70182708
复制相似问题