1. 程式人生 > >CentOS 6.9系統時間和硬件時間設置(轉)

CentOS 6.9系統時間和硬件時間設置(轉)

計算 時間同步 紅色 執行 sysinit 2個 本地 混亂 關閉

總結一下hwclock,這個容易暈:

1)/etc/sysconfig/clock 文件,只對 hwclock 命令有效,且只在系統啟動和關閉的時候才有用(修改了其中的 UTC=true 到 UTC=false 的前後,執行 hwclock (--utc, 或 --localtime) 都沒有變化,要重啟系統後才生效);

2)/etc/rc.d/rc.sysinit 文件,run once at boot time,其中有從硬件時鐘同步時間到系統時間的操作;

3)hwclock --localtime 的輸出,才是硬件時鐘真正的時間。如果輸出結果帶時區(比如CST),還要看/etc/sysconfig/clock裏的UTC參數,如果 UTC=false,那時區有意義;如果 UTC=true,那時區沒意義,實際上是UTC時間。

4)在 /etc/sysconfig/clock 中 UTC=false 時,date、hwclock、hwclcok --localtime 輸出的時間應該都一致,且此時 hwclock --utc是沒有意義的;

5)在 /etc/sysconfig/clock 中 UTC=ture 時,date、hwclock 的輸出是一致的,hwclock --localtime 的輸出則是UTC時間;

6)如果不想在輸出中帶時區,則 export LANG=C ,然後再運行 hwclock 就沒有什麽CST了,免得時區誤導你;

7)hwclock --utc 很鬧騰,還是別看了,你會暈的。。。

8)系統關閉時會同步系統時間到硬件時鐘,系統啟動時會從硬件時鐘讀取時間更新到系統,這2個步驟都要根據 /etc/sysconfig/clock 文件中UTC的參數來設置時區轉換。

實際案例分析

修改了 /etc/sysconfig/clock 中UTC參數但系統未正常關閉的情況

修改 /etc/sysconfig/clock 文件後,如果系統內核突然崩潰,然後直接按電源重啟,則系統沒有進行 系統時間到硬件時鐘的 同步;但是 系統啟動時,又根據 /etc/sysconfig/clock 中UTC的參數,來同步硬件時鐘到系統,這時就會出現時間問題:

0)假設系統的時區為CST(UTC+8);

1)假設原 /etc/sysconfig/clock 中 UTC=true,修改成 UTC=false;

2)如果此時系統未正常關機,系統時間未按參數 UTC=false 同步時間到硬件時鐘(沒有+8小時);

3)但系統被按電源重啟後,系統讀取到 UTC=false,認為硬件時鐘為CST時間,直接用於系統時間;

4)那麽此時,系統時間將少了8小時。

一、首先要弄清幾個概念:

1. “系統時間”與“硬件時間”

系統時間: 一般說來就是我們執行 date 命令看到的時間,linux系統下所有的時間調用(除了直接訪問硬件時間的命令)都是使用的這個時間。

硬件時間: 主板上BIOS中的時間,由主板電池供電來維持運行,系統開機時要讀取這個時間,並根據它來設定系統時間(註意:系統啟動時根據硬件時間設定系統時間的過程可能存在時區換算,這要視具體的系統及相關設置而定)。

2. “UTC時間”與“本地時間”

UTC時間:Coordinated Universal 8 e2 i( H7 t0 ^/ ^Time 世界協調時間(又稱世界標準時間、世界統一時間),在一般精度要求下,它與GMT(Greenwich Mean Time,格林威治標準時間)是一樣的,其實也就是說 GMT≈UTC,但 UTC 是以原子鐘校準的,更精確。

本地時間:由於處在不同的時區,本地時間一般與UTC是不同的,換算方法就是

本地時間 = UTC + 時區 或 UTC = 本地時間 - 時區

時區東為正,西為負,例如在中國,本地時間都使用北京時間,在linux上顯示就是 CST(China Standard Time,中國標準時,註意美國的中部標準時Central Standard Time也縮寫為CST,與這裏的CST不是一回事!),時區為東八區,也就是 +8 區,所以 CST=UTC+(+8小時) 或 UTC=CST-(+8小時)。

二、時間命令

1. 系統時間 date

直接調用 date,得到的是本地時間。如果想得到UTC時間的話,使用 date -u。

[12-01 19:07> ~]$ date
2009年 12月 07日 星期一 14:22:20 CST
[12-01 19:07> ~]$ date -u
2009年 12月 07日 星期一 06:22:22 UTC

2. 硬件時間 /sbin/hwclock

直接調用 /sbin/hwclock 顯示的時間就是 BIOS 中的時間嗎?未必!這要看 /etc/sysconfig/clock 中是否啟用了UTC,如果啟用了UTC(UTC=true),顯示的其實是經過時區換算的時間而不是BIOS中真正的時間,如果加上 –localtime 選項,則得到的總是 BIOS 中實際的時間.

[12-01 19:07> ~]# hwclock
2009年12月07日 星期一 14時28分43秒 -0.611463 seconds
[12-01 19:07> ~]# hwclock --utc
2009年12月07日 星期一 14時28分46秒 -0.594189 seconds
[12-01 19:07> ~]# hwclock --localtime
2009年12月07日 星期一 06時28分50秒 -0.063875 seconds

3. /etc/localtime

這個文件用來設置系統的時區,將 /usr/share/zoneinfo/ 中相應文件拷貝到/etc下並重命名為 localtime 即可修改時區設置,而且這種修改對 date 命令是及時生效的。不論是 date 還是 hwclock 都會用到這個文件,會根據這個文件的時區設置來進行UTC和本地之間之間的換算。

4. /etc/sysconfig/clock

這個文件只對 hwclock 有效,而且似乎是只在系統啟動和關閉的時候才有用,比如修改了其中的 UTC=true 到 UTC=false 的前後,執行 hwclock (--utc, 或 --localtime) 都沒有變化,要重啟系統後才生效。註:如果設置 UTC=false 並重啟系統後,執行一些命令結果如下:

date 2009年 12月 07日 星期一 19:26:29 CST
date -u 2009年 12月 07日 星期一 11:26:29 UTC
hwclock 2009年12月07日 星期一 19時26分30秒 -0.442668 seconds
hwclock --utc 2009年12月08日 星期二 03時26分31秒 -0.999091 seconds
hwclock --localtime 2009年12月07日 星期一 19時26分32秒 -0.999217 seconds

可見,如果不使用UTC,BIOS時間(紅色部分)就是系統本地時間,而且註意這時執行 hwclock --utc 得到的結果沒有任何意義,因為這裏我們已經禁用了UTC,而且也明顯不符合“本地時間=UTC+時區”的關系。

三、linux與windows雙系統間的時間同步

系統啟動和關閉時,硬件時間與系統時間之間的同步有兩種方式(假設在中國,用CST代表本地時間):

方式A: 使用UTC(對linux就是 /etc/sysconfig/clock 中 UTC=true)

開機: BIOS——->UTC(將BIOS中的時間看成是UTC)——(時區變化)—–>CST

關機: CST ——-(時區變化)—–>UTC——-存儲到——>BIOS

方式B: 不使用UTC(對linux就是 /etc/sysconfig/clock 中 UTC=false)

開機: BIOS———————>CST(將BIOS中的時間看成是CST)

關機: CST ———存儲到——>BIOS

FIX:

方式A: 使用UTC(對linux就是 /etc/sysconfig/clock 中 UTC=true)

關機: CST ——-操作系統根據時區算出UTC時間——-存儲到——>BIOS

開機: BIOS——->BIOS中的時間是UTC———–操作系統根據時區計算出localtime———-CST

方式B: 不使用UTC(對linux就是 /etc/sysconfig/clock 中 UTC=false)

關機: CST ——–操作系統中UTC=false,直接將localtime存儲到——>BIOS

開機: BIOS——–BIOS中的時間是localtime—–操作系統中UTC=false,BIOS時間當成localtime——–>CST(將BIOS中的時間看成是CST)

通過設定 /etc/sysconfig/clock,linux可以支持這兩種方式,然而windows只支持方式B(至少是默認支持B,而我不知道怎麽能讓它支 持A),那麽在雙系統情況下,如果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時間的,於是手動的設置便被覆蓋掉了。

參考:

http://abcdxyzk.github.io/blog/2016/01/06/system-base-time/(以上內容轉自此篇文章)

CentOS 6.9系統時間和硬件時間設置(轉)