您的位置:首页 > 运维架构 > Tomcat

Linux java Tomcat 项目中 new Date 获取时间 8小时 时差

2016-11-25 13:19 483 查看

起因:在本地开发的WEB项目部署到Linux 下后,存入数据库的时间少了8个小时。

首先想到的肯定是时区问题

linux 下直接 执行 date 命令
Fri Nov 25 11:28:18 CST 2016


时间正常。然后简单java类,打印new Date时间

public class TestDate {
public static void main(String[] args) throws Exception {
System.out.println(new Date());
}
}
------运行结果
Fri Nov 25 11:29:31 CST 2016


确定linux,JDK 时间正常

但是Tomcat下 jsp打印时间,少了8个小时

<%@ include file="/WEB-INF/views/include/taglibs.jsp"%>
<%@ page language="java" pageEncoding="utf-8"%>
<jsp:useBean id="now" class="java.util.Date" />
${now}


Fri Nov 25 04:43:51 GMT 2016


明显jsp中打印的时间时区为GMT

CET,UTC,GMT,CST几种常见时间概述与关系

已经过以上测试,可能是Tomcat问题,那么修改tomcat 启动参数

http://free.yes81.net/yes81/view-13576.html

按照以上方式修改后,tomcat内Date时间正常

过程中还发现一个问题我的系统中

/etc/sysconfig/clock 文件只有一行(文件说明

ZONE="Asia/Shanghai"


并没有这两行。

UTC=false
ARC=false


加上后,tomcat不修改时间也是正常。后经过搜索返现一篇博文

http://blog.tangjianwei.com/2009/06/04/the-problem-of-tomcat-timezone/

启动提到:

tomcat读取的可能是硬件时间(BIOS时间)



UTC=false

UTC – 指定BIOS中保存的时间是否是GMT/UTC时间,true表示BIOS里面保存的时间是UTC时间,false表示BIOS里面保存的时间是本地时间。

所以判断 可能为之前没有设置 /etc/sysconfig/clock 中 UTC=false,倒置tomcat读取时区出现问题倒置。

到此问题基本解决。不过对于时区其中的好多概念理解还不是很清楚,以后有时间整理一下。

其他相关博文

http://escode.blog.51cto.com/2025829/1147439
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  tomcat java linux