项目更换了部署环境后出现了奇怪的现象:时间少了8个小时,查看日志发现时间戳的日期是正常的,而date类型的日期是少了8小时的。最后导致页面上要展示的时间也少了8小时。
本地调试时时间是正常的,但是部署到测试环境后就出现了时差问题。
最后折腾很久搞清楚几个问题:
- java部署在docker容器中,如果容器的时区是国际时间,而代码里没有做任何设定,时间是会变成国际时间的
- date转json时会变成时间戳
- date转成了时间戳,无论你是什么时区,什么格式的date,时间戳都不受影响,他会判断时区与格式
- mongodb里的时间格式是IOSDate,是国际时间,比北京时间少8小时
- mongodb里的日期拿出来,如果变成时间戳,会是北京时间的时间戳
解决方案:
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
//设置中国时区
formatter.setTimeZone(TimeZone.getTimeZone("Asia/Shanghai"));
String surveyBeginDate = :formatter.format(info.getSurveyBeginDate());
这样需要在每个地方都转换,不太方便,如果是springBoot的系统,可以在spring启动文件里加代码:
@PostConstruct
void started() {
TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));
}
亲测有效!
spring mvc的应用没有试过加这个可不可以,猜想应该也可以的
最后和运维大大沟通后,是由于项目部署到docker容器中,java项目启动时获取时区没有获取到北京时区。
最后运维大大帮助下在加载docker容器时设定时间,就不需要在代码中设定时区了。