博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaWeb 项目与系统时间相差 8 个小时的问题
阅读量:6257 次
发布时间:2019-06-22

本文共 2323 字,大约阅读时间需要 7 分钟。

hot3.png

写在前面

今天记录分享一个排查部署到 Linux 上的 web 项目执行的时间和本地系统时间相差 8 小时的问题

环境:redhat 6.5 考虑有规律的时间差可能和时区不同有关

1 查看 Linux 系统时间和时区

[root@localhost ~]# date2019年 03月 31日 星期日 16:00:32 CST[root@localhost ~]# date -RSun, 31 Mar 2019 16:00:44 +0800[root@localhost ~]# date +"%Z %z"CST +0800

从这里可以确定,系统的时间和时区正常(北京时间,也就是东八区),时区详情请看

2 查看 jvm 时间和时区

2.1 先在 Linux 上某个目录执行 javac ,看 javac 命令是否可用,出现如下显示就可以(中间部分已省略)

[root@localhost test]# javac用法: javac 
其中, 可能的选项包括: -g 生成所有调试信息 -g:none 不生成任何调试信息 -g:{lines,vars,source} 只生成某些调试信息 ...... -X 输出非标准选项的提要 -J
<标记>
直接将
<标记>
传递给运行时系统 -Werror 出现警告时终止编译 @
<文件名>
从文件读取选项和文件名

2.2 编写测试程序

import java.util.TimeZone;import java.util.Date;public class time {    public static void main(String[] args) {        System.out.println("当前时间:"+new Date());        System.out.println("当前默认时区:"+TimeZone.getDefault());    }}

2.3 编译执行

[root@localhost test]# javac time.java [root@localhost test]# ll总用量 8-rw-r--r-- 1 root root 780 3月  31 16:02 time.class-rw-r--r-- 1 root root 239 3月  31 16:00 time.java[root@localhost test]# java time当前时间:Sun Mar 31 08:02:34 CTM 2019当前默认时区:sun.util.calendar.ZoneInfo[id="GTM",offset=28800000,dstSavings=0,useDaylight=false,transitions=29,lastRule=null]

这里有导其他的包,如果以上命令不好使,则使用如下命令 (中间的点 . 是当前目录的意思)

[root@localhost test]# javac -d . time.java[root@localhost test]# ll总用量 8-rw-r--r-- 1 root root 780 3月  31 16:03 time.class-rw-r--r-- 1 root root 239 3月  31 11:00 time.java[root@localhost test]# java -cp . time当前时间:Sun Mar 31 08:02:40 CST 2019当前默认时区:sun.util.calendar.ZoneInfo[id="GTM",offset=28800000,dstSavings=0,useDaylight=false,transitions=29,lastRule=null]

这里显然 jvm 的时间比系统的时间早了 8 个小时,且是格林威治的时区,所以这里修改 jvm 的时区即可,这里说下,网上查询说 jvm 的时区默认读取的是硬件时区,目录为 /etc/sysconfig/clock (),查看如下

[root@localhost test]# cat /etc/sysconfig/clock ZONE="Asia/Shanghai"

与网上对比,这里没有下面这两行

UTC=falseARC=false

这里看有人说是没有设置 UTC=false 导致的问题,查看资料说 UTC 指定 BIOS 中保存的时间是否是 GMT/UTC 时间,true 表示 BIOS 里面保存的时间是 UTC 时间,false 表示 BIOS 里面保存的时间是本地时间。 加上后有的机器还是不好使,如果是在 tomcat 下运行的项目,那就重启 tomcat 即可。

如果还不好使,还有修改 tomcat 配置文件的方法,欢迎参考之前的文章:

现在问题基本已解决,以上有些内容是客户现场出现的,所以现在记录时也是凭笔记和记忆回忆的,如有偏差也请不吝赐教。

文章参考:

转载于:https://my.oschina.net/charmsongo/blog/3030429

你可能感兴趣的文章
1_NAT模式和桥接模式下的网络配置
查看>>
EF架构~为EF DbContext生成的实体添加注释(T5模板应用)
查看>>
【转】VLAN原理详解
查看>>
python --- json模块和pickle模块详解
查看>>
idea中artifacts、facets、modules是什么意思?
查看>>
FUCKED-BUG之临时对象的生死
查看>>
SP2 PRIME1 - Prime Generator
查看>>
创建和编辑 crontab 文件
查看>>
钉钉发消息
查看>>
20172309_《程序设计与数据结构(下)》_课堂测试修改报告。
查看>>
(二十九)方法调用之解析
查看>>
Springboot文件上传与下载
查看>>
Activity与Fragment数据传递之Fragment从Activity获取数据 分类: ...
查看>>
记一次小的51CTO聚会
查看>>
架構設計_案例說明_by 高老師
查看>>
VR內容開發(PAGE-2)
查看>>
飞舞的蝴蝶
查看>>
Linux环境下C语言模拟内存负载测试
查看>>
专栏《轻松玩转ELK海量可视化日志分析系统》已完结【附代码下载】
查看>>
新手IT人员,如何找到适合自己专业书籍的6个问题?
查看>>