LinuxNTP服务器配置详解
时间:2026-03-25 11:24:43 352浏览 收藏
本文详解如何在Linux系统中正确配置内网NTP服务器,重点纠正常见误区——默认启用的systemd-timesyncd仅支持客户端同步、无法提供授时服务;推荐使用更现代、稳定且对虚拟化友好的chrony替代ntpd,并手把手指导禁用冲突服务、修改chrony.conf关键参数(如bindaddress 0.0.0.0和allow网段)、开放防火墙UDP 123端口、验证监听状态及客户端强制指向内网源等核心步骤,同时深入剖析“LastRx: never”等典型故障背后真实的网络层拦截原因,助你避开90%的配置坑,快速搭建高可用内网时间同步体系。

怎么确认系统用的是 systemd-timesyncd 还是 ntpd/chrony
很多 Linux 发行版默认启用了 systemd-timesyncd,它是个轻量 NTP 客户端,但不能当服务器用。如果你执行 timedatectl status 看到 NTP service: active,别急着以为能对外授时——那只是它在同步自己,不是在服务别人。
真正能当内网 NTP 服务器的,目前主流就两个:chrony(推荐)和 ntpd(老旧,已不建议新部署)。chrony 对虚拟机、断连、网络抖动更友好,启动快,精度不输 ntpd,且配置简单。
- 检查是否装了 chrony:
chronyd --version或which chronyd - 如果只有
systemd-timesyncd,得先禁用:sudo systemctl stop systemd-timesyncd && sudo systemctl disable systemd-timesyncd - Ubuntu/Debian 装 chrony:
sudo apt install chrony;CentOS/RHEL:sudo yum install chrony或sudo dnf install chrony
chrony.conf 怎么改才能对外提供时间服务
默认的 /etc/chrony/chrony.conf 是客户端配置,关键是要加一条 allow 指令,并确保监听地址不是 127.0.0.1。否则内网其他机器发请求会直接被拒绝或超时。
常见错误是只加了 allow 192.168.1.0/24 却没改 bindcmdaddress 和 bindaddress,结果 chronyd 仍只监听本地回环,外部根本连不上。
- 打开配置文件:
sudo nano /etc/chrony/chrony.conf - 注释掉或删掉原有的
pool或server行(这是客户端行为,服务器不需要主动去同步别人) - 加上这三行(按需调整网段):
bindaddress 0.0.0.0 bindcmdaddress 0.0.0.0 allow 192.168.10.0/24
bindaddress 0.0.0.0让 chronyd 监听所有接口;allow控制谁可以查询时间;bindcmdaddress是为chronyc命令本地管理留的,也放开更省事- 重启服务:
sudo systemctl restart chronyd,再用ss -tuln | grep :123确认 UDP 123 端口已在监听
客户端怎么正确指向你的内网 NTP 服务器
客户端如果还配着公网 NTP 池(比如 pool.ntp.org),或者同时写了多个 server,chrony 默认会做“选择最优源”,可能跳过你的内网服务器。要让它**强制只用内网源**,就得关掉兜底行为。
另一个坑是防火墙:很多发行版默认关 UDP 123,服务器和客户端都要检查 ufw 或 firewalld 是否放行。
- 客户端配置(
/etc/chrony/chrony.conf):pool 192.168.10.1 iburst # 删掉所有其他 server/pool 行 # 加上这行,避免 fallback 到公网 rtcsync makestep 1 -1
iburst加速初始同步;makestep允许大步调时(否则时钟偏差 > 5 秒会拒绝校正)- 检查客户端时间状态:
chronyc tracking(看“System time”是否在同步)、chronyc sources -v(确认来源是你配的 IP) - 防火墙放行(以 ufw 为例):
sudo ufw allow 123/udp
为什么客户端显示“LastRx: never”或“Offline”
这不是 chrony 自己的问题,而是典型网络层阻断。UDP 包无声无息丢了,chrony 日志里往往只写一句 Source XXX.XXX.XXX.XXX not responding,让人误以为配置错了。
最容易被忽略的是:宿主机开了防火墙、云服务器安全组没开 UDP 123、虚拟机桥接模式下网卡未桥接到物理网络、甚至交换机 ACL 限制了 NTP 流量。
- 先在服务器本机测通不通:
chronyc -h 127.0.0.1 sources—— 如果这都失败,说明 chronyd 没跑起来或 bind 失败 - 再从客户端 ping 服务器 IP,确认三层可达;然后用
nc -u -zv 192.168.10.1 123(部分 nc 不支持 UDP,可换timeout 2 bash -c 'echo >/dev/udp/192.168.10.1/123' 2>/dev/null && echo ok || echo fail) - 查服务器端收包:
sudo tcpdump -i any -n udp port 123,看客户端请求是否真到了 - chrony 默认不记详细日志,如需排查,临时加
logdir /var/log/chrony和log measurements statistics tracking,再重启
内网授时看着简单,实际卡点全在“谁拦了 UDP 包”。配置写对了,网络链路一通,基本就稳了。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
241 收藏
-
441 收藏
-
266 收藏
-
280 收藏
-
382 收藏
-
124 收藏
-
240 收藏
-
403 收藏
-
117 收藏
-
373 收藏
-
185 收藏
-
201 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习