總結一下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時間的,於是手動的設置便被覆蓋掉了。
四、采用CST方案后配置時間同步到BIOS
1)vim /etc/sysconfig/clock #編輯時間配置文件 ZONE="Asia/Shanghai" #CST,本地時間 UTC=false #設置為false,硬件時鍾不與UTC時間一致 ARC=false 2)ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime #linux的時區設置為上海時區 3)ntpdate cn.pool.ntp.org #對准時間(安裝:sudo yum install ntp) 4)/sbin/hwclock --systohc #設置硬件時間和系統時間一致並校准
參考:
http://abcdxyzk.github.io/blog/2016/01/06/system-base-time/(以上內容轉自此篇文章)