對於集群和分布式等大型系統來說,時間及其同步是個很重要的問題。經過對redhat linux及JRE(包括oracle JRE,IBM JRE)的研究,現總結如下。
1,時間的查看
通常的時間可分為local時間和UTC時間,local時間在linux下使用date查看:
# date
Wed Oct 31 17:38:06 BRST 2012
通常這個時間是指所在時區和包括了夏令時計算的時間值。所有使用linux時間的系統打印出的時間都是這個。
UTC時間是指標准格林威治及零時區的時間,不包含夏令時的計算。UTC時間查看方式是:
# date -u
Wed Oct 31 19:38:12 UTC 2012
基本上:Local時間=UTC時間+時區時間差+夏令時時間差
還有硬件時間,及BIOS上存儲的時間,查看方式:
# hwclock
Wed 31 Oct 2012 05:38:16 PM BRST -0.328544 seconds
為了查看JRE的時間,我們寫了一個工具:
# cat TestTimeZone.java
import java.text.SimpleDateFormat; import java.util.Date; import java.util.TimeZone; public class TestTimeZone { private static String DEFAULT_FORMAT = "yyyy-MM-dd HH:mm:ss.SSS (z)"; private static SimpleDateFormat sdf = new SimpleDateFormat(DEFAULT_FORMAT); public static void main(String args[]) { Date dt = new Date(); System.out.println("Current time:\t"+ sdf.format(dt)); sdf.setTimeZone(TimeZone.getTimeZone("UTC")); System.out.println("UTC time:\t"+ sdf.format(dt)); System.out.println("Env variable user.timezone:" + System.getProperty(""user.timezone")); } }
為了兼容低版本JRE,采用JDK1.4編譯,運行:
#/usr/java/j2sdk1.4.2/bin/java TestTimeZone.java
#java TestTimeZone
Current time: 2012-10-31 15:57:47.014 (BRST)
UTC time: 2012-10-31 17:57:47.014 (UTC)
Env variable user.timezone :America/Bahia
2,Linux時間及JRE的時間關系
先解釋下相關配置文件:
/etc/localtime: linux 系統的時區文件,定義linux的時區和夏令時規則
/etc/sysconfig/clock: linux和JRE度要用到的文件,可能沒有這個文件,文件內容如:
cat /etc/sysconfig/clock
# The ZONE parameter is only evaluated by system-config-date.
# The timezone of the system is defined by the contents of /etc/localtime.
ZONE="Asia/Shanghai"
UTC=true
ARC=false
ZONE是指時區,對JRE會起作用,對linux會被/etc/localtime中的定義覆蓋
UTC是指硬件存儲的是否為UTC時間,若為true,則硬件時間當做UTC時間,linux系統啟動時會將此事件加上時區和夏令時的差額計算出local時間;若為false則硬件中的時間就是local時間,時區和夏令時規則失效。
當linux系統啟動時,首先讀取硬件時間,然後根據以上配置文件中的定義計算出時間。
但JRE的時間是獨立處理的,JRE自己如linux樣獨立取得硬件時間,然後根據JRE的時區和夏令時規則計算出JRE的時間。JRE的時區確定規則為:首先確定是否有TZ系統變量(亦為user.timezone, 在啟動java程序時亦可通過參數-Duser.timezone單獨指定),若有則取TZ變量中的值,若無則取/etc/sysconfig/clock 中的ZONE值。
由上可知,更新時區和夏令時規則時需要同時更新linux和JRE的相關配置和規則的。Linux的夏令時規則在/usr/share/zoneinfo/下;Oracle JRE夏令時規則在:$JAVA_HOME/lib/zi;IBM JRE夏令時規則在$IBM_JAVA_HOME/lib/core.jar。
本文出自 “小何貝貝的技術空間” 博客,請務必保留此出處http://babyhe.blog.51cto.com/1104064/1045570