导读

在Linux服务器中如果我们希望所有Linux服务器都具有正确的时间,则必须配置一些NTP客户端,该客户端将始终从远程NTP服务器获取正确的时间。

 

安装chrony

使用下面命令在Centos8中安装chrony:


[root@server1 ~]# yum -y install chrony


chrony安装完成之后,会有两个可执行程序:

  • chronyc: chrony命令行工具
  • chronyd: chrony的守护进程

Chrony的配置文件

Chrony的配置文件是/etc/chrony.conf,下面列出了示例chrony.conf文件:


[root@server1 ~]# cat /etc/chrony.conf


centos 容器的文件在什么地方 centos8 chrony_配置文件

pool 2.centos.pool.ntp.org iburst chrony将从中获取时间的远程NTP服务器。

driftfile /var/lib/chrony/drift 系统时钟频率都有小小的误差,这个就是为什么计算机运行一段时间后时间会不精确。NTP会自动来监测我们时钟的误差值并予以调整,所以它会把记录下来的误差先写入driftfile,重新启动系统后,之前的计算结果也就不会丢失了。

keyfile /etc/chrony.keys 该文件包含用于NTP身份验证的密钥。

logdir /var/log/chrony 它是记录Chrony的日志文件。

测试chrony

就像ntpdate命令一样,我们可以使用chronyd手动将Linux服务器的时间与远程NTP服务器进行同步。

语法:


chronyd -q ‘server {ntp_server_name} iburst’


下面使用实例:


[root@server1 ~]# chronyd -q 'server s1a.time.edu.cn iburst'
2021-05-25T01:59:38Z chronyd version 3.5 starting (+CMDMON +NTP +REFCLOCK +RTC +PRIVDROP +SCFILTER +SIGND +ASYNCDNS +SECHASH +IPV6 +DEBUG)
2021-05-25T01:59:38Z Initial frequency -4.035 ppm
2021-05-25T01:59:42Z System clock wrong by -0.006248 seconds (step)
2021-05-25T01:59:42Z chronyd exiting


centos 容器的文件在什么地方 centos8 chrony_服务器_02


从上面的输出中可以看到,chrony已校正了系统时间。

Start和Enable chronyd服务

运行以下命令以启用chronyd服务:


[root@server1 ~]# systemctl enable chronyd[root@server1 ~]# systemctl start chronyd


运行下面命令查看chronyd的服务状态:


[root@server1 ~]# systemctl status chronyd


centos 容器的文件在什么地方 centos8 chrony_sed_03

验证chrony的同步

要验证系统时间是否已使用chrony同步,使用以下命令查看:


[root@server1 ~]# chronyc tracking Reference ID    : 4E2E66B4 (electrode.felixc.at)
Stratum         : 4
Ref time (UTC)  : Tue May 25 02:04:47 2021
System time     : 0.000002501 seconds slow of NTP time
Last offset     : +0.016273908 seconds
RMS offset      : 0.016273908 seconds
Frequency       : 98.064 ppm fast
Residual freq   : +1.774 ppm
Skew            : 155.311 ppm
Root delay      : 0.227135062 seconds
Root dispersion : 0.028634518 seconds
Update interval : 64.4 seconds
Leap status     : Normal


Reference ID 是系统时间当前同步到的服务器的ID和名称。

检查chrony来源

要列出有关chronyd使用的当前时间源的信息,请运行以下命令:


[root@server1 ~]# chronyc sources210 Number of sources = 4
MS Name/IP address         Stratum Poll Reach LastRx Last sample               
===============================================================================
^- electrode.felixc.at           3   6   377    29    -14ms[  -14ms] +/-  137ms
^- ntp7.flashdance.cx            2   6   377    91  +2336us[+2505us] +/-  174ms
^? ntp8.flashdance.cx            0   6     0     -     +0ns[   +0ns] +/-    0ns
^* 111.230.189.174               2   6   377    28   +423us[ +648us] +/-   50ms


centos 容器的文件在什么地方 centos8 chrony_服务器_04


要列出有关chronyd使用的每个源的漂移速度和偏移估计的信息,请运行以下命令:

[root@server1 ~]# chronyc sourcestats  -v210 Number of sources = 4                             .- Number of sample points in measurement set.
                            /    .- Number of residual runs with same sign.
                           |    /    .- Length of measurement set (time).
                           |   |    /      .- Est. clock freq error (ppm).
                           |   |   |      /           .- Est. error in freq.
                           |   |   |     |           /         .- Est. offset.
                           |   |   |     |          |          |   On the -.
                           |   |   |     |          |          |   samples. \
                           |   |   |     |          |          |             |
Name/IP Address            NP  NR  Span  Frequency  Freq Skew  Offset  Std Dev
==============================================================================
electrode.felixc.at        12   5   527     -2.019     22.417    -13ms  2921us
ntp7.flashdance.cx         10   5   397     +1.957     29.018  +2410us  2684us
ntp8.flashdance.cx          0   0     0     +0.000   2000.000     +0ns  4000ms
111.230.189.174            12   9   527     -0.001     10.537    -60ns  1360us


centos 容器的文件在什么地方 centos8 chrony_服务器_05

配置Chrony NTP服务

如果你要将Linux服务器配置为所有内部系统的Chrony NTP服务器。我们需要在/etc/chrony.conf配置文件中稍作修改:


[root@server1 ~]# sed -i "s/#local stratum 10/local stratum 10/g" /etc/chrony.conf[root@server1 ~]# sed -i "s/#allow 192.168.0.0\/16/allow 192.168.0.0\/16/" /etc/chrony.conf


centos 容器的文件在什么地方 centos8 chrony_centos 容器的文件在什么地方_06


当我们取消注释local stratum 10行时,则使我们的Linux服务器成为实时NTP服务器,即使它与网络断开连接也可以继续正常工作。而allow 192.168.0.0/26表示允许该网段的设备连接到我们的Chrony NTP服务器以进行时间同步。

更改后,重启chrony服务并跟踪chrony:


[root@server1 ~]# systemctl restart chronyd ; watch chronyc tracking


centos 容器的文件在什么地方 centos8 chrony_sed_07


使用以下命令在防火墙中允许NTP服务:

[root@server1 ~]# firewall-cmd --permanent --add-service=ntpsuccess[root@server1 ~]# firewall-cmd --reloadsuccess


centos 容器的文件在什么地方 centos8 chrony_sed_08

总结

这就是本文的全部内容,希望你能了解如何使用chrony服务将Linux的时间与NTP服务器同步。Linux就该这么学