最近项目部署到服务器上,发现时间不对,与当前时间相差12个小时,第一反应是 系统时间是不是不对。通过date 命令查看,


发现系统用的是est 时区 (EST eastern standard time (美国)东部标准时间  慢北京时间 13个小时。)

那就是简单了 ,修改下时区就好了。于是按照晚上的命令将系统时区修改了下。时间正常了,重新运行程序,问题仍能存在,还是相差13个小时。以为是有缓存什么的,能后就重启系统试试,重启后再次运行程序,还是相差13个小时 ,被这个快搞得精疲力尽了 

 能后写了个测试接口放到服务器上。通过调用发现。返回的时间还是忙13个小时。刚刚好,不多一份也不少一秒,所以猜测还是时区的问题。所以顺便也打印了下时区。发现时区还是EST 时区没有变过来。 


能后上午搜索了下,发现也有网友遇到过相似的问题,他给出的解决方案是

当然我会给出解决方案:

方法一:JVM运行时增加参数,指定时区 -D user.timezone=GMT+08

方法二:直接在程序中设置时区。System.setProperty(“user.timezone”,”GMT +08″);

方法三:直接加上28800就好了(8hours*60min*60sec=28800)



照着这位网友的思路。和搜索相关操作步骤,在tomcat 启动的时候,设置个默认时区方法是在 catalina.sh 文件中添加如下这行代码

JAVA_OPTS="$JAVA_OPTS -Dfile.encoding=UTF8  -Duser.timezone=GMT+08"

重新启动tomcat  正常了。


不过不知道为什么,系统的时区已经修改了,但是程序获取到的时区还是没有修改过来,不知道这个是不是和服务器有关因为服务器用的是虚机,都是在一台服务器上虚拟出来的。程序获取的不是虚机的时间,而且主机的时间。 以上只是猜测,还待验证