问题现象
- 客户的服务器已部署好平台,放入了机房,运行正常。服务器系统时间设置东八区(
CST
),时间日期也已修改正确 - 客户是我省的某小县城,某台晚上,他们大楼停电断电了,包括机房(就几台机器,没做应急电源)
- 等来电后,服务器重启,我们的平台也通过开机自启动运行的脚本,正确完成了重启,但访问平台时发现日期时间不对
- 当地维护人员,手动修改了时间(装的是有界面的
CentOS
系统),重启了我们平台(修改日期时间后,部署在docker
服务要重启,时间才会跟着改对),然后将问题反馈给了我 - 因为他们当地无法避免再次的断电情况,不能每次都手动修改配置
排查与解决
- 和维护人员沟通了下,问他时间不对,是什么情况,是快了还是慢了,但是遗憾的是他记不清了
- 如果时间是为
1990年1月1日
或2000年1月1日
,应该是时钟固件电池没电了,还是要根据具体的时间来排查 - 今天中午,让他再次模拟下断电现象(去机房把服务器关机,然后拔掉电源线,等一会再开机),协助排查问题
- 首先使用
timedatectl
命令查看系统时间,发现时区设置是对的,时间则刚好差8小时,实际应该是2023-05-23 13:55:51
- 先手动将时间设置正确(使用
date -s
或timedatectl set-time
),再继续排查
date -s "2023-05-23 13:56:00"
timedatectl set-time "2023-05-23 13:56:00"
- 然后,输入命令
hwclock --show
查看硬件时钟时间,果然硬件时间不对,存储的是+8
后的时间
- 最后,使用命令
hwclock --systohc
把系统时间写入硬件,再使用命令hwclock --show
查看,发现已经生效
- 此时系统时间和硬件时间统一,显示也都没问题了,继续断电重启一次,时间显示正常,问题解决
- 一句话总结下,系统时间与硬件时间不一致,硬件时间存储了
CST
时间(应该存储UTC
),导致断电重启后增加了8小时。将系统时间同步到硬件时间后,生效解决
时间同步与设置
- 系统时间误差八小时,一般都是时区设置错误导致的,可以参考我这篇博客:【已解决】CentOS7等linux系统时区时间不对显示误差8小时
- 时区设置完成后,将时间设置正确。如果是联网的机器,可以获取网络时间校时,再设置一个联网自动校时
- 如果是内网或者局域网,看有没有时间服务器,如果有一台时间服务器,也可以设置下与时间服务器同步,参考我这篇博客:CentOS7.9设置ntp时间同步
- 如果无法连接互联网,也没有时间同步服务器,就只能依赖机器的时钟固件了。服务器断电后,服务内内置的
BIOS
芯片的小电池会继续供电,继续持续记录时间(需要电池有电)。这次遇到的问题,一开始问了当地运维是新机器,应该不会没电。
服务器时钟介绍
- 服务器时钟通常是通过全球卫星定位系统(
GPS
)或者时间服务器同步的。时钟同步是非常关键的,因为如果服务器上的时钟不准确,会导致许多问题,比如日志记录不准确、安全证书失效等等 - 主板
BIOS
电池是一种小型的电池,通常被用来存储主板上的系统设置和时钟时间。在某些情况下,如果服务器无法连接到时间服务器或者GPS
信号不稳定等问题,时钟同步可能会失败,这时候主板BIOS
电池就会发挥作用,可以保证服务器时钟不会出现太大的偏差 - 服务器通常具有内置的实时时钟(
RTC
),其主要作用是提供精确的时间戳来记录系统事件、备份和还原数据以及控制计划任务等。在断电时,RTC电池可以提供电源来维护时钟和日历芯片,确保在断电后系统时间仍然能够精确地被维护,这样可以避免数据损失和系统崩溃等问题 - BIOS电池是指主板上的一块可更换,负责提供电源给
BIOS
芯片的小电池。这玩意更换成本很低,电池好像就几块钱,就是更换时需要注意静电损坏设备,可以提前摸下金属放电
BIOS电池的作用是为了让BIOS芯片保持一些重要的设置,如系统时间、启动顺序、CPU电压等。如果没有这个电池,每次电脑断电后这些设置都会被清空,需要重新设置。因此,BIOS电池非常重要,一旦电池失效则会导致系统出现各种异常。文章来源:https://www.toymoban.com/news/detail-457199.html
- 断电时钟是指在电脑断电后依然能够保持系统时间的功能。服务器在断电后,依靠主板可以保持内部时钟的精度和准确性。
断电时钟则是一种通过硬件设计实现的功能,它可以让系统在断电状态下保持时间,这样开机后系统时间就不会出现错误。断电时钟是由主板、BIOS和操作系统三者共同实现的,其中主板和BIOS负责提供硬件和基本的系统时间管理功能,操作系统负责根据断电时钟提供的时间进行更为精确的时间管理。文章来源地址https://www.toymoban.com/news/detail-457199.html
- 维护服务器时,需要定期检查
RTC
电池的状态和健康状况,确保其功能和性能,以保证服务器能够正常工作 - 如果
BIOS
芯片电池已耗尽或完全失效,断电重启后,日期和时间将被重置为固定的默认值。每个计算机的默认日期和时间可能有所不同,但通常为1990年1月1日
或2000年1月1日
。在这种情况下,您需要手动调整日期和时间,否则这可能会影响计算机的正确运行。
到了这里,关于linux服务器断电重启后,发现时间误差八小时的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!