linux时间与Windows时间不一致问题

linux时间与Windows时间不一致问题

一、几个概念

  1. “系统时间”与“硬件时间”

系统时间: 一般说来就是我们执行 date命令看到的时间,linux系统下所有的时间调用(除了直接访问硬件时间的命令)都是使用的这个时间。

硬件时间:主板上BIOS中的时间,由主板电池供电来维持运行,系统开机时要读取这个时间,并根据它来设定系统时间(注意:系统启动时根据硬件时间设定系统时间的过程可能存在时区换算,这要视具体的系统及相关设置而定)。

  1. “UTC时间”与“本地时间”
  • UTC时间:UTC即Universal Time Coordinated,协调世界时(又称世界标准时间、世界统一时间),在一般精度要求下,它与GMT(Greenwich Mean Time,格林威治标准时间)是一样的,其实也就是说 GMT≈UTC,但 UTC 是以原子钟校准的,更精确。

  • 本地时间:由于处在不同的时区,本地时间一般与UTC是不同的,换算方法就是:本地时间 = UTC +时区 或 UTC = 本地时间 - 时区. 时区东为正,西为负,例如在中国,本地时间都使用北京时间,在linux上显示就是 CST(China StandardTime,中国标准时,注意美国的中部标准时Central StandardTime也缩写为CST,与这里的CST不是一回事!),时区为东八区,也就是 +8 区,所以CST=UTC+(+8小时) 或 UTC=CST-(+8小时)。

Windows 与 Mac/Linux 缺省看待系统硬件时间的方式是不一样的:

  • Windows把系统硬件时间当作本地时间(local time),即操作系统中显示的时间跟BIOS中显示的时间是一样的。
  • Linux/Unix/Mac把硬件时间当作 UTC,操作中显示的时间是硬件时间经过换算得来的,比如说北京时间是GMT+8,则系统中显示时间是硬件时间+8。

二、时间命令

  1. 系统时间 date
    直接调用date,得到的是本地时间。如果想得到UTC时间的话,使用 date -u
[root@fedora vm]# date
Sun Aug 21 08:59:20 PM CST 2022
[root@fedora vm]# date -u
Sun Aug 21 12:59:23 PM UTC 2022
  1. 硬件时间 /sbin/hwclock
    直接调用 /sbin/hwclock 显示的时间就是BIOS 中的时间吗?未必!这要看是否启用了UTC,如果启用了UTC(UTC=true),显示的其实是经过时区换算的时间而不是BIOS中 真正的时间,如果加上–localtime 选项,则得到的总是 BIOS 中实际的时间.
[root@fedora vm]# hwclock
2022-08-21 20:57:49.444294+08:00
[root@fedora vm]#  hwclock --utc
2022-08-21 20:58:08.824916+08:00
[root@fedora vm]# hwclock --localtime
2022-08-21 12:58:17.211330+08:00
  1. /etc/localtime
    这个文件用来设置系统的时区,将/usr/share/zoneinfo/ 中相应文件拷贝到/etc下并重命名为 localtime 即可修改时区设置,而且这种修改对date 命令是及时生效的。不论是 date 还是 hwclock都会用到这个文件,会根据这个文件的时区设置来进行UTC和本地之间之间的换算。

可见,如果不使用UTC,BIOS时间就是系统本地时间,而且注意这时执行 hwclock --utc得到的结果没有任何意义,因为这里我们已经禁用了UTC,而且也明显不符合“本地时间=UTC+时区”的关系。

三、linux与windows双系统间的时间同步

系统启动和关闭时,硬件时间与系统时间之间的同步有两种方式(假设在中国,用CST代表本地时间):
方式A: 使用UTC

  • 开机: BIOS--------->UTC(将BIOS中的时间看成是UTC)------(时区变化)----->CST
  • 关机:CST-------(时区变化)----->UTC-------存储到------>BIOS

方式B: 不使用UTC

  • 开机: BIOS----------------------->CST(将BIOS中的时间看成是CST)
  • 关机:CST---------存储到------>BIOS

如果linux设成A方式,那么在linux与windows系统切换时一定会造成时间混乱的,解决办法就是将 linux中的UTC禁用,也设成B方式就可以了。

注:可以通过 hwclock --hctosys来利用硬件时间来设置系统时间(注意不是简单的复制BIOS中的时间为系统时间,要看是否使用UTC,如果使用的话则要做时区换算), 通过hwclock --systohc 来根据系统时间设置硬件时间(也要看是否启用UTC来决定是否做时区换算)。总之,不论使用–systohc 还是 --hctosys,同步后直接运行不带参数的 hwclock 得到的时间与直接运行 date得到的时间应该一致,这个时间是否就是BIOS中的时间(hwclock–localtime)那就不一定了,如果启用了UTC就不是,没启用 UTC就是。
而且还要注意:在系统中手动使用 hwclock hwclock --set --date='yyyy-mm-dd'来设置BIOS时间只在系统运行时有效,因为当系统关闭时,还会按设定好的方式根据系统时间来重设BIOS时间的,于是手动的设置便被覆盖掉了。

解决办法:

1.修改Windows的时间设定:

让 Windows 把硬件时间当作 UTC
开始->运行->CMD,打开命令行程序(Vista则要以管理员方式打开命令行程序方可有权限访问注册表),在命令行中输入下面命令并回车
Reg add HKLM\SYSTEM\CurrentControlSet\Control\TimeZoneInformation /v RealTimeIsUniversal /t REG_DWORD /d 1

2.修改linux 时间设定,将BIOS时间作为本地时间:

使用timdatectl命令设置:

$ timedatectl status | grep local
#将硬件时间设置为 localtime:
# timedatectl set-local-rtc true

硬件时间设置成 UTC(恢复默认设置):

# timedatectl set-local-rtc false
posted @ 2022-08-28 23:34  main_c  阅读(1728)  评论(0编辑  收藏  举报