现象描述
将项目部署好之后,发现统计部分根据时间统计的数量不对
问题分析步骤
- 去数据查看时间是北京时间还是世界时间,发现存储的时间是北京时间,而统计是根据数据库里存储的是世界时间进行统计的
- 查看时间是怎么生成的,发现不对的时间都是通过new Date生成的,而Linux的系统时间是世界时间,结果new Date()的时间为北京时间
- 通过测试发现TimeZone tz = TimeZone.getDefault()
在服务器上获取的时区是北京时间
4.通过观察发现是jar包启动时参数不对,时区应已世界时间启动
注意事项
在本地new Date()取的是本地电脑的北京时间,而在服务器上就获取的是世界时间了,所以在调试的时候改下本机电脑的时间,模拟下Linux环境的时间
解决办法
- 在启动器类上加入
@PostConstruct
void setDefaultTimezone() {
TimeZone.setDefault(TimeZone.getTimeZone("UTC"));
}
2.jar包启动时添加参数
nohup //后台启动(结束程序时杀死进程即可)
java
-jar -Dfile.encoding=utf-8 //需要加这个,否则当配置文件中有中文启动会报错
-Dspring.profiles.active=test //nacos的dev/test
-Dname=jar包名称.jar
-Duser.timezone=GMT //时区设置
-Xms512M -Xmx512M
-XX:MetaspaceSize=16M
-XX:+HeapDumpOnOutOfMemoryError
-XX:+PrintGCDateStamps
-XX:+PrintGCDetails
-XX:NewRatio=1
-XX:SurvivorRatio=30
-XX:+UseParallelGC
-XX:+UseParallelOldGC
./jar包名称.jar &