0

0

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

舞夢輝影

舞夢輝影

发布时间:2025-12-24 22:53:02

|

462人浏览过

|

来源于php中文网

原创

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)冲突和服务异常。

viable
viable

基于GPT-4的AI非结构化数据分析平台

下载

用 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 解析能力。

相关专题

更多
数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

324

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2066

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

346

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

250

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

315

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

400

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

363

2023.10.16

vb连接数据库的方法
vb连接数据库的方法

vb连接数据库的方法有使用ADO对象库、使用OLEDB数据提供程序、使用ODBC数据源等。详细介绍:1、使用ADO对象库方法,ADO是一种用于访问数据库的COM组件,可以通过ADO连接数据库并执行SQL语句。可以使用ADODB.Connection对象来建立与数据库的连接,然后使用ADODB.Recordset对象来执行查询和操作数据;2、使用OLEDB数据提供程序方法等等。

216

2023.10.19

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 5.9万人学习

Git 教程
Git 教程

共21课时 | 2.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号