关于服务器上(Docker中)运行Java程序时区异常记录
2017-10-27 14:54
399 查看
前言
生产环境:4台阿里云服务器搭建的kubernetes单master集群
遇到问题:
Java应用的时间差8个小时,导致根据时间判断的业务逻辑异常,测试小姐姐对于下了订单的前端显示时间和真实时间差8个小时很恼火~开发初期就已经存在,或许因为写业务也比较赶,一直拖着,而最近小组调整,这个问题随之到了我的账下,顾记录下解决的方法。
问题定位
服务器和本机的时区查看对比
查看系统时区
服务器的时区和容器(Java应用运行)都是正常的
服务器地址也是正常的
在Java应用中获取时区
启动类中加入下面的代码:本地输出:Asia/Shanghai 中国标准时间
服务器上输出:Etc/UTC Coordinated Universal Time
解决方式
经过上述比较,在容器中运行的Java应用获取到的时区是以伦敦为标准而不是容器的时区,正巧看到桥er桑的一篇文章,写到了在docker容器中运行的java应用打出的日志时间和通过date -R方式获取的容器标准时间有八个小时时间差~用到了他提供的第二种方法,在main函数启动时候加入VM参数,运行指令如下:java -jar -Duser.timezone=GMT+08 XXX.jar具体在k8s启动文件中体现为:
修改以后重启PODS,可以看到效果如下:
总结
首先[桥er桑]的第一种方法我在容器中并没有找到路径下的相关文件,在yaml文件加入环境变量配置无效其次有同事之前在代码里面format设置时区,不过并没有解决这个问题,在此我也没进行过多尝试
kubernetes不知道是否有更好的解决方案,希望得到k8s大神的指导~可以更方便的解决这个问题
在非Java语言应用,或者Tomcat下运行的Java应用,不知道这个问题存不存在,需要了解到底层机制才能真正的明白这个问题,希望在彻底明白以后再好好记录一番。
相关文章推荐
- 关于java实现的mapreduce程序打包后通过脚本运行出现classnotfound异常
- 关于java程序的运行方式.
- 关于六种Java异常处理程序的陋习
- 关于 Java源文件带有package的普通程序和Applet编译和运行时错误的处理方法
- Property文件找不到异常-java程序在Linux下运行出错
- 关于六种Java异常处理程序的陋习
- crontab 运行java程序的异常——crontab配置环境变量
- 关于将java程序导成.exe,在没有装jvm的机器上运行
- 关于计算Java程序运行时间
- 关于计算Java程序运行时间 及Java代码--JUnit
- 关于计算Java程序运行时间
- 关于dos窗口下运行java程序,中文字符打印成乱码的心得总结
- 关于计算java程序运行时间
- 关于计算Java程序运行时间
- 关于java运行命令行程序输出的问题
- 关于android工程下不能运行java main程序的解决办法
- 关于六种Java异常处理程序的陋习
- 关于eclipse运行java程序内存溢出的解决方法
- 关于六种Java异常处理程序的陋习
- 关于 Java源文件带有package的普通程序和Applet编译和运行时错误的处理方法