从 NTP 到 Chrony,掌握 Linux 系统时间同步机制

在现代计算机系统中,保证时间的同步是保障系统稳定运行和数据一致性的关键因素。

而对于 Linux 系统而言,传统的 NTP(Network Time Protocol)协议长期以来扮演着时间同步中不可或缺的重要角色,但其安全性和精度局限性日益凸显。

本文将深入探讨 Linux 系统时间同步机制,并介绍 Chrony 这一更为现代化的时间同步解决方案。

传统方案:NTP

NTP 协议凭借其简单易用性,长期以来一直是 Linux 系统时间同步的首选方案。只需几条简单的命令,即可完成 NTP 的配置:

ntpdate pool.ntp.org
systemctl enable --now ntp

很简单,对吧?

然而,NTP 协议本身存在一些安全隐患,例如被恶意攻击者利用发起 NTP 反射攻击。攻击者通过发送伪造源 IP 地址的请求,诱骗 NTP 服务器向目标系统发送大量数据包,从而形成分布式拒绝服务攻击 (DDoS) 链条中最重要的 NTP 反射攻击

攻击者可以利用某些 NTP 命令(如 monlist)发起放大攻击,放大倍数可达 200 倍。

NTP 协议的精度在某些对时间同步要求极高的场景下也显得捉襟见肘。例如,在金融交易、高性能计算等领域,要求毫秒/微秒级的时间同步是一种刚需。

更现代的解决方案

鉴于 NTP 的局限性,Chrony 应运而生。作为一种更为现代化的时间同步解决方案,Chrony 不仅提供了更高的同步精度和安全性,而且配置更为简便灵活。

在 Debian/Ubuntu 系的系统中,可以使用以下命令快速安装和启动 Chrony 服务:

apt update
apt install chrony
systemctl enable --now chronyd

Chrony 的配置文件位于 /etc/chrony/chrony.conf,可以配置指定的时间服务器和其他高级选项。

nano /etc/chrony/chrony.conf

例如,以下配置指定 Chrony 使用 Debian 提供的 NTP 服务器池进行时间同步:

pool 2.debian.pool.ntp.org iburst