1. 程式人生 > >Debian下系統時間比正常時間快8小時的問題

Debian下系統時間比正常時間快8小時的問題

先說時區的配置。以前Debian有個好勝的時區配置工具,叫tzconfig,現在也沒有了。但配置時區倒也簡單,主要是兩個檔案:

/etc/localtime

/etc/timezone

timezone這個檔案是個文字,裡面只需要寫一行自己的時區就行,我們這裡就是上海,Asia/Shanghai(誰知道為什麼不是北京呢?)。 localtime這個檔案的型別不清楚,裡面就寫了些timezone data,它可以從系統自帶時區檔案那裡拷貝,位置在:/usr/share/zoneinfo

從這個目錄下找到Shanghai拷貝到/etc下的localtime即可。有人說建個連線也可,這樣還可以保證系統資料有變化時不必再管。

設定了時區,還要確定Linux的時間方案。Linux支援UTC時間,Coordinated Universal Time,也就是世界協調時,也就是本初子午線上的時間,它和以前的格林威治標準時(GMT)的區別似乎是它是由多個原子鐘平均出來的。在 /etc/default/rcS這個檔案中,設定了系統是否使用UTC,UTC=yes就是用。

計算機自己還有自己的時間,也就是硬體時間,hard clock,也就是存在BIOS裡那個時間,關機也不會丟失。計算機啟動時,就要讀取這個時間。這個時間如果設定為UTC(GMT),也就是倫敦那地方的時間,就要在rcS檔案中設定UTC=yes,反之則要設為no。

總之就是兩種正確的設定:

BIOS=本地時間,UTC=no

BIOS=UTC時間,UTC=yes

一般來講,BIOS裡面都設定為當地時間,這是因為如果裝雙系統的話,Windows似乎不懂utc,就會出問題。這時UTC=no。

如果一切順利,到這時,進入Linux之後顯示的時間應該是正確的了。但不少人的機器,包括這回這臺640m,仍舊不正確,而是比正確時間再往前跑了8小時。這裡的問題出在Linux讀取硬體時間上了。

Linux讀取這個硬體時間要用到hwclock這個命令:

hwclock --show :顯示硬體時間

hwclock --systohc :將系統時間寫入硬體

hwclock --hctosys :將硬體時間寫入系統時間

在出問題的時候,hwclock 這一組命令的執行通常是不能成功的,錯誤經常是這樣的:

select() to /dev/rtc to wait for clock tick timed out

也就是不能讀取/dev/rtc,也就是硬體時間。這又是因為某些機器的BIOS處理方式和Linux的rtc核心模組之間出現了問題。

Linux又有3個這類模組,rtc/genrtc/rtc_dev,似乎是一個比一個新,而debian通常自己用的是rtc這個老模組;但 Dell/ibm/acer等等廠商現在都可能使用新的BIOS,這種BIOS和這個rtc就可能不對付。如果出現了上面那個timeout的問題,有兩種方法可以解決:

1, 給hwclock加引數,--directisa,也就是:

hwclock --directisa --show

如果執行成功,說明這個辦法可行。則把此引數新增為hwclock的預設引數即可。在debian 4.0之後,可以直接在/etc/default/rcS中新增一行:

HWCLOCKPARS="--directisa“

而在4.0以前,可能只能在hwclock啟動指令碼中新增,/etc/init.d/hwclock.sh,把裡面的”/sbin/hwclock“ 全部替換為 ”/sbin/hwclock --directisa"。現在在debian sid中,這個指令碼的第一行其實是HWCLOCKPARS=,也可以像rcS一樣新增引數了。

2, 換用其他核心rtc模組,用如下方法測試哪個模組好用:

# modprobe rtc

# hwclock --show

# rmmod rtc

# modprobe genrtc

# hwclock --show

# rmmod genrtc

# modprobe rtc_dev

# hwclock --show

# rmmod rtc_dev

沒有顯示time out的就是好用的了,然後可以在blacklist中阻止不好用的,在modules裡面加上好用的那個。

用完這兩個方法,hwclock應該能直接工作了,也就是可以讀取硬體時間了。再配上utc設定正確,重啟之後時間就是對的了。

為了讓BIOS時間更準確,除了可以找個精確的時間源,比如CDMA手機或是GPS,靠自己的手指來精確設定BIOS時間之外,還可以用hwclock把準確的時間寫入BIOS。前一種方法細心點可以做到幾秒誤差,而後一種怎麼也在1秒以下了。

安裝ntpdate這個包,它可以從時間伺服器上讀取到正確的時間,精度還是很高的:

aptitude install ntpdate

ntpdate pool.ntp.org

此時系統時間就已經是ntp的時間了,相當精確,把它寫入硬體:

hwclock --systohc

這樣BIOS時間也就很準了。以後開機沒網路,沒辦法執行ntpdate的時候也都是準的。

這裡的關鍵有:bios時間,utc設定,rtc模組,hwclock讀取,ntpdate對時。

在Debian的老bug裡還看到因為系統有多個分割槽,比如/usr單獨分,fsck執行時會對時,並因此又造成快幾個小時的問題,不知道怎麼處理的。