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

当将本地开发的WEB项目部署到Linux服务器后,发现存入数据库的时间比实际少了8小时。初步判断为时区问题。通过检查Linux、JDK时间正常,但在Tomcat环境下JSP打印时间显示异常。经排查,问题出在Tomcat配置上,通过调整Tomcat启动参数及修复/etc/sysconfig/clock文件内容,解决了时区问题。同时了解到Tomcat可能读取硬件时间(BIOS时间),UTC配置影响了时间显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

起因:在本地开发的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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值