Linux时间不同步怎么办_ntp与chrony使用讲解【教程】

7次阅读

Linux 时间不同步会影响日志、SSL/TLS、集群通信和数据库一致性;应先用 timedatectl 和 chronyc/ntpq 检查状态,优先选用 chrony(现代发行版默认),配置可靠 NTP 源并启用 makestep,同步后校准硬件时钟、确认时区与防火墙设置。

Linux 时间不同步怎么办_ntp 与 chrony 使用讲解【教程】

Linux 时间不同步会直接影响日志记录、SSL/TLS 证书验证、集群节点通信、数据库事务一致性等关键功能。解决的核心思路是:先确认当前时间状态,再选择合适 工具 chronyNTP)完成同步,并确保长期稳定运行。

先检查时间状态和偏差

执行以下命令快速诊断:

  • timedatectl status —— 查看系统是否启用网络时间同步、本地时钟状态、RTC(硬件时钟)与系统时钟是否一致
  • chronyc tracking(chrony 启用时)或 ntpq -p(ntpd 启用时)—— 查看当前同步源、偏移量(offset)、延迟(delay)
  • date -Rhwclock --show —— 对比系统时间与硬件时间,若相差过大(如超 5 分钟),NTP/chrony 默认可能拒绝同步,需先手动校准

选 chrony 还是 ntp?看系统版本和场景

RHEL/CentOS 7 及更新版本(含 Rocky、AlmaLinux、BCLinux 8.2+)、Ubuntu 20.04+ 等主流发行版默认使用 chrony,它更适合 虚拟化 环境、断网波动大、启动频繁的服务器,同步更快、精度更高、对时钟漂移适应更强。

NTP(ntpd) 更适合物理机长期稳定运行、对传统 Stratum 分层有明确要求的场景,但 RHEL 8+、CentOS 8+ 已移除官方支持,需额外安装且不推荐新部署。

注意:chrony 和 ntpd 不能共存 ,卸载一个再装另一个,避免 端口(123/udp)冲突和服务异常。

用 chrony 快速同步(推荐方案)

适用于绝大多数现代 Linux 发行版:

  • 安装并启用服务:yum install -y chrony && systemctl enable --now chronyd(RHEL 系)或 apt install -y chrony && systemctl enable --now chrony(Debian/Ubuntu)
  • 编辑 /etc/chrony.conf,替换为可靠源(例如 阿里云):
    server ntp.aliyun.com iburst
    server time1.cloud.tencent.com iburst
  • 若需立即生效(尤其首次或偏差大时):chronyc -a makestep
  • 验证结果:chronyc sources -v(看到 ^* 表示主同步源正常),chronyc tracking 中 Offset 应在 ±50ms 内

时间同步后还需注意硬件时钟

Linux 启动时从 RTC(BIOS 时钟)读取初始时间,关机前可将系统时间写回硬件时钟,避免重启后时间跳变:

  • 查看当前硬件时钟是否与系统时间一致:hwclock --compare
  • 同步系统时间到硬件时钟:hwclock --systohc
  • 确认时区正确:timedatectl set-timezone Asia/Shanghai(避免 UTC 与本地时间混淆)
  • 开启自动同步硬件时钟(chrony 默认已配置):timedatectl set-ntp true

不复杂但容易忽略的是:DNS 能否解析 NTP 域名、防火墙 是否放行 UDP 123 端口、云主机是否限制外网 NTP 请求(部分厂商需配内网时间源)。排查时优先确认网络连通性和 DNS 解析能力。

星耀云
版权声明:本站原创文章,由 星耀云 2025-12-28发表,共计1407字。
转载说明:转载本网站任何内容,请按照转载方式正确书写本站原文地址。本站提供的一切软件、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。
text=ZqhQzanResources