linux服务器断电重启后,发现时间误差八小时

文章目录

    • 问题现象
    • 排查与解决
    • 时间同步与设置
    • 服务器时钟介绍

问题现象

  • 客户的服务器已部署好平台,放入了机房,运行正常。服务器系统时间设置东八区(CST),时间日期也已修改正确
  • 客户是我省的某小县城,某台晚上,他们大楼停电断电了,包括机房(就几台机器,没做应急电源)
  • 等来电后,服务器重启,我们的平台也通过开机自启动运行的脚本,正确完成了重启,但访问平台时发现日期时间不对
  • 当地维护人员,手动修改了时间(装的是有界面的CentOS系统),重启了我们平台(修改日期时间后,部署在docker服务要重启,时间才会跟着改对),然后将问题反馈给了我
  • 因为他们当地无法避免再次的断电情况,不能每次都手动修改配置

排查与解决

  • 和维护人员沟通了下,问他时间不对,是什么情况,是快了还是慢了,但是遗憾的是他记不清了
  • 如果时间是为1990年1月1日2000年1月1日,应该是时钟固件电池没电了,还是要根据具体的时间来排查
  • 今天中午,让他再次模拟下断电现象(去机房把服务器关机,然后拔掉电源线,等一会再开机),协助排查问题
  • 首先使用timedatectl命令查看系统时间,发现时区设置是对的,时间则刚好差8小时,实际应该是2023-05-23 13:55:51
    linux服务器断电重启后,发现时间误差八小时_第1张图片
  • 先手动将时间设置正确(使用date -stimedatectl set-time),再继续排查
date -s "2023-05-23 13:56:00"
timedatectl set-time "2023-05-23 13:56:00"
  • 然后,输入命令hwclock --show查看硬件时钟时间,果然硬件时间不对,存储的是+8后的时间
    linux服务器断电重启后,发现时间误差八小时_第2张图片
  • 最后,使用命令hwclock --systohc把系统时间写入硬件,再使用命令hwclock --show查看,发现已经生效
    -
  • 此时系统时间和硬件时间统一,显示也都没问题了,继续断电重启一次,时间显示正常,问题解决
  • 一句话总结下,系统时间与硬件时间不一致,硬件时间存储了CST时间(应该存储UTC),导致断电重启后增加了8小时。将系统时间同步到硬件时间后,生效解决

时间同步与设置

  • 系统时间误差八小时,一般都是时区设置错误导致的,可以参考我这篇博客:【已解决】CentOS7等linux系统时区时间不对显示误差8小时
  • 时区设置完成后,将时间设置正确。如果是联网的机器,可以获取网络时间校时,再设置一个联网自动校时
  • 如果是内网或者局域网,看有没有时间服务器,如果有一台时间服务器,也可以设置下与时间服务器同步
  • 如果无法连接互联网,也没有时间同步服务器,就只能依赖机器的时钟固件了。服务器断电后,服务内内置的BIOS芯片的小电池会继续供电,继续持续记录时间(需要电池有电)。这次遇到的问题,一开始问了当地运维是新机器,应该不会没电。

服务器时钟介绍

  • 服务器时钟通常是通过全球卫星定位系统(GPS)或者时间服务器同步的。时钟同步是非常关键的,因为如果服务器上的时钟不准确,会导致许多问题,比如日志记录不准确、安全证书失效等等
  • 主板BIOS电池是一种小型的电池,通常被用来存储主板上的系统设置和时钟时间。在某些情况下,如果服务器无法连接到时间服务器或者GPS信号不稳定等问题,时钟同步可能会失败,这时候主板BIOS电池就会发挥作用,可以保证服务器时钟不会出现太大的偏差
  • 服务器通常具有内置的实时时钟(RTC),其主要作用是提供精确的时间戳来记录系统事件、备份和还原数据以及控制计划任务等。在断电时,RTC电池可以提供电源来维护时钟和日历芯片,确保在断电后系统时间仍然能够精确地被维护,这样可以避免数据损失和系统崩溃等问题
  • BIOS电池是指主板上的一块可更换,负责提供电源给BIOS芯片的小电池。这玩意更换成本很低,电池好像就几块钱,就是更换时需要注意静电损坏设备,可以提前摸下金属放电

BIOS电池的作用是为了让BIOS芯片保持一些重要的设置,如系统时间、启动顺序、CPU电压等。如果没有这个电池,每次电脑断电后这些设置都会被清空,需要重新设置。因此,BIOS电池非常重要,一旦电池失效则会导致系统出现各种异常。

  • 断电时钟是指在电脑断电后依然能够保持系统时间的功能。服务器在断电后,依靠主板可以保持内部时钟的精度和准确性。

断电时钟则是一种通过硬件设计实现的功能,它可以让系统在断电状态下保持时间,这样开机后系统时间就不会出现错误。断电时钟是由主板、BIOS和操作系统三者共同实现的,其中主板和BIOS负责提供硬件和基本的系统时间管理功能,操作系统负责根据断电时钟提供的时间进行更为精确的时间管理。

  • 维护服务器时,需要定期检查RTC电池的状态和健康状况,确保其功能和性能,以保证服务器能够正常工作
  • 如果BIOS芯片电池已耗尽或完全失效,断电重启后,日期和时间将被重置为固定的默认值。每个计算机的默认日期和时间可能有所不同,但通常为1990年1月1日2000年1月1日。在这种情况下,您需要手动调整日期和时间,否则这可能会影响计算机的正确运行。

你可能感兴趣的:(Linux,异常报错,linux,服务器,运维)