Chrony:一个类Unix系统上NTP客户端和服务器替代品

系统 Linux
在这个教程中,我们会讨论如何安装和配置 Chrony,一个类 Unix 系统上 NTP 客户端和服务器的替代品。Chrony 可以更快的同步系统时钟,具有更好的时钟准确度,并且它对于那些不是一直在线的系统很有帮助。

[[249834]]

 在这个教程中,我们会讨论如何安装和配置 Chrony,一个类 Unix 系统上 NTP 客户端和服务器的替代品。Chrony 可以更快的同步系统时钟,具有更好的时钟准确度,并且它对于那些不是一直在线的系统很有帮助。Chrony 是自由开源的,并且支持 GNU/Linux 和 BSD 衍生版(比如 FreeBSD、NetBSD)、macOS 和 Solaris 等。

安装 Chrony

Chrony 可以从大多数 Linux 发行版的默认软件库中获得。如果你使用的是 Arch Linux,运行下面的命令来安装它:

  1. $ sudo pacman -S chrony

在 Debian、Ubuntu、Linux Mint 上:

  1. $ sudo apt-get install chrony

在 Fedora 上:

  1. $ sudo dnf install chrony

当安装完成后,如果之前没有启动过的话需启动 chronyd.service 守护进程:

  1. $ sudo systemctl start chronyd.service

使用下面的命令让它每次重启系统后自动运行:

  1. $ sudo systemctl enable chronyd.service

为了确认 chronyd.service 已经启动,运行:

  1. $ sudo systemctl status chronyd.service

如果一切正常,你将看到类似下面的输出:

  1. chrony.service - chrony, an NTP client/server
  2. Loaded: loaded (/lib/systemd/system/chrony.service; enabled; vendor preset: ena
  3. Active: active (running) since Wed 2018-10-17 10:34:53 UTC; 3min 15s ago
  4. Docs: man:chronyd(8)
  5. man:chronyc(1)
  6. man:chrony.conf(5)
  7. Main PID: 2482 (chronyd)
  8. Tasks: 1 (limit: 2320)
  9. CGroup: /system.slice/chrony.service
  10. └─2482 /usr/sbin/chronyd
  11.  
  12. Oct 17 10:34:53 ubuntuserver systemd[1]: Starting chrony, an NTP client/server...
  13. Oct 17 10:34:53 ubuntuserver chronyd[2482]: chronyd version 3.2 starting (+CMDMON
  14. Oct 17 10:34:53 ubuntuserver chronyd[2482]: Initial frequency -268.088 ppm
  15. Oct 17 10:34:53 ubuntuserver systemd[1]: Started chrony, an NTP client/server.
  16. Oct 17 10:35:03 ubuntuserver chronyd[2482]: Selected source 85.25.84.166
  17. Oct 17 10:35:03 ubuntuserver chronyd[2482]: Source 85.25.84.166 replaced with 2403
  18. Oct 17 10:35:03 ubuntuserver chronyd[2482]: Selected source 91.189.89.199
  19. Oct 17 10:35:06 ubuntuserver chronyd[2482]: Selected source 106.10.186.200

可以看到,Chrony 服务已经启动并且正在工作!

配置 Chrony

NTP 客户端需要知道它要连接到哪个 NTP 服务器来获取当前时间。我们可以直接在该 NTP 配置文件中的 server 或者 pool 项指定 NTP 服务器。通常,默认的配置文件位于 /etc/chrony/chrony.conf 或者 /etc/chrony.conf,取决于 Linux 发行版版本。为了更可靠的同步时间,建议指定至少三个服务器。

下面几行是我的 Ubuntu 18.04 LTS 服务器上的一个示例。

  1. [...]
  2. # About using servers from the NTP Pool Project in general see (LP: #104525).
  3. # Approved by Ubuntu Technical Board on 2011-02-08.
  4. # See http://www.pool.ntp.org/join.html for more information.
  5. pool ntp.ubuntu.com iburst maxsources 4
  6. pool 0.ubuntu.pool.ntp.org iburst maxsources 1
  7. pool 1.ubuntu.pool.ntp.org iburst maxsources 1
  8. pool 2.ubuntu.pool.ntp.org iburst maxsources 2
  9. [...]

从上面的输出中你可以看到,NTP 服务器池项目 已经被设置成为了默认的时间服务器。对于那些好奇的人,NTP 服务器池项目是一个时间服务器集群,用来为全世界千万个客户端提供 NTP 服务。它是 Ubuntu 以及其他主流 Linux 发行版的默认时间服务器。

在这里, * iburst 选项用来加速初始的同步过程 * maxsources 代表 NTP 源的最大数量

请确保你选择的 NTP 服务器是同步的、稳定的、离你的位置较近的,以便使用这些 NTP 源来提升时间准确度。

在命令行中管理 Chronyd

chrony 有一个命令行工具叫做 chronyc 用来控制和监控 chrony 守护进程(chronyd)。

为了检查是否 chrony 已经同步,我们可以使用下面展示的 tracking 命令。

  1. $ chronyc tracking
  2. Reference ID : 6A0ABAC8 (t1.time.sg3.yahoo.com)
  3. Stratum : 3
  4. Ref time (UTC) : Wed Oct 17 11:48:51 2018
  5. System time : 0.000984587 seconds slow of NTP time
  6. Last offset : -0.000912981 seconds
  7. RMS offset : 0.007983995 seconds
  8. Frequency : 23.704 ppm slow
  9. Residual freq : +0.006 ppm
  10. Skew : 1.734 ppm
  11. Root delay : 0.089718960 seconds
  12. Root dispersion : 0.008760406 seconds
  13. Update interval : 515.1 seconds
  14. Leap status : Normal

我们可以使用命令确认现在 chrony 使用的时间源:

  1. $ chronyc sources
  2. 210 Number of sources = 8
  3. MS Name/IP address Stratum Poll Reach LastRx Last sample
  4. ===============================================================================
  5. ^- chilipepper.canonical.com 2 10 377 296 +102ms[ +104ms] +/- 279ms
  6. ^- golem.canonical.com 2 10 377 302 +105ms[ +107ms] +/- 290ms
  7. ^+ pugot.canonical.com 2 10 377 297 +36ms[ +38ms] +/- 238ms
  8. ^- alphyn.canonical.com 2 10 377 279 -43ms[ -42ms] +/- 238ms
  9. ^- dadns.cdnetworks.co.kr 2 10 377 1070 +40ms[ +42ms] +/- 314ms
  10. ^* t1.time.sg3.yahoo.com 2 10 377 169 -13ms[ -11ms] +/- 80ms
  11. ^+ sin1.m-d.net 2 10 275 567 -9633us[-7826us] +/- 115ms
  12. ^- ns2.pulsation.fr 2 10 377 311 -75ms[ -73ms] +/- 250ms

chronyc 工具可以对每个源进行统计,比如使用 sourcestats 命令获得漂移速率和进行偏移估计。

  1. $ chronyc sourcestats
  2. 210 Number of sources = 8
  3. Name/IP Address NP NR Span Frequency Freq Skew Offset Std Dev
  4. ==============================================================================
  5. chilipepper.canonical.com 32 16 89m +6.293 14.345 +30ms 24ms
  6. golem.canonical.com 32 17 89m +0.312 18.887 +20ms 33ms
  7. pugot.canonical.com 32 18 89m +0.281 11.237 +3307us 23ms
  8. alphyn.canonical.com 31 20 88m -4.087 8.910 -58ms 17ms
  9. dadns.cdnetworks.co.kr 29 16 76m -1.094 9.895 -83ms 14ms
  10. t1.time.sg3.yahoo.com 32 16 91m +0.153 1.952 +2835us 4044us
  11. sin1.m-d.net 29 13 83m +0.049 6.060 -8466us 9940us
  12. ns2.pulsation.fr 32 17 88m +0.784 9.834 -62ms 22ms

如果你的系统没有连接到互联网,你需要告知 Chrony 系统没有连接到 互联网。为了这样做,运行:

  1. $ sudo chronyc offline
  2. [sudo] password for sk:
  3. 200 OK

为了确认你的 NTP 源的状态,只需要运行:

  1. $ chronyc activity
  2. 200 OK
  3. 0 sources online
  4. 8 sources offline
  5. 0 sources doing burst (return to online)
  6. 0 sources doing burst (return to offline)
  7. 0 sources with unknown address

可以看到,我的所有源此时都是离线状态。

一旦你连接到互联网,只需要使用命令告知 Chrony 你的系统已经回到在线状态:

  1. $ sudo chronyc online
  2. 200 OK

为了查看 NTP 源的状态,运行:

  1. $ chronyc activity
  2. 200 OK
  3. 8 sources online
  4. 0 sources offline
  5. 0 sources doing burst (return to online)
  6. 0 sources doing burst (return to offline)
  7. 0 sources with unknown address

所有选项和参数的详细解释,请参考其帮助手册。

  1. $ man chronyc
  2. $ man chronyd

这就是文章的所有内容。希望对你有所帮助。在随后的教程中,我们会看到如何使用 Chrony 启动一个本地的 NTP 服务器并且配置客户端来使用这个服务器同步时间。

保持关注!

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2018-12-20 08:50:53

TCPIP服务器

2010-01-11 13:05:24

VNC server配

2010-03-01 16:10:32

Linux Samba

2010-03-19 09:26:34

Java Socket

2018-04-12 10:55:41

Android服务器数据

2011-03-28 17:24:26

2012-05-07 13:55:41

JavaJava Web

2019-05-07 10:00:03

ChronyNTPLinux

2022-06-14 15:07:04

IPC客户端服务端

2019-05-05 10:42:22

LinuxNTP命令

2024-04-02 09:42:39

2022-06-29 15:40:28

MinecraftMinetest开源

2012-10-30 09:30:49

IaaS基础架构即服务IaaS案例

2022-12-03 15:53:46

开源Linux

2023-03-29 13:13:34

2014-06-01 11:03:13

VDI零客户端

2009-09-17 18:06:44

Nis服务器

2020-12-01 17:46:24

FossilGit

2021-11-10 18:40:24

exa命令 ls命令Linux

2021-12-29 18:18:59

开源MedusaShopify
点赞
收藏

51CTO技术栈公众号