经常会遇到一个问题:时间不对,比正常时间多或者少几个小时,这种情况可能是时区问题导致的。
已知
- 数据库时区:东八区
- 虚拟机时区(服务):东八区
- 服务器时区:东八区
问题
服务新增数据时,通过new Date()创建的时间,存入数据库后发现数据库中的时间小8个小时。
但是服务从数据库中查询出来的时间又是正常的
原因
出现问题的原因可能是:项目的数据库配置指定了serverTimezone=UTC。
UTC时间为零时区的时间,比东八区时间慢8小时。当新增时间写入数据库时,得知指定的数据库时区为UTC,会先将时间转化为减8小时,再传到数据库,数据库得到的时间显然会少8小时
写入数据库流程:
- new Date()创建的时间时,得到服务器时间、服务器时区、虚拟机时区
- 比对虚拟机时区和服务器时区,转换服务器时间得到虚拟机时间
- 虚拟机时间写入数据库时,比对虚拟机时区和数据库时区(由项目的数据库配置指定serverTimezone=UTC),转换虚拟机时间的到数据库时间(此时的时间已经少了8小时),时间写入数据库
查询数据库流程:
- 查询数据库得到数据库时间(此时的时间已经少了8小时)
- 比对数据库时区(由项目的数据库配置指定serverTimezone=UTC)和虚拟机时区
,转换数据库时间得到虚拟机时间(此时的时间已经比数据库时间多了8小时,所以变成了正常时间)
关于UTC可参考文章:UTC时间、CST时间和GMT时间