数据存入es 时间差了8个小时

 Mysql

 这种现象其实是正常的,因为es默认存储时间的格式是UTC时间,我们一般用的是UTC+8

存入Es后应该是在原来的基础上(UTC+8)-8=UTC 存入到Es后就变成我们看到的样子了

首先知道几个时间名词:

(1)GMT:格林威治标准时间

(2)UTC:世界协调时间

(3)DST:夏日节约时间

(4)CST:中国标准时间

其中GMT时间可以近似认为和UTC时间是相等的,但从精度上来说UTC时间更精确。其误差值必须保持在0.9秒以内

CST= GMT + 8 =UTC + 8

从上面可以看出来中国的时间是等于UTC时间+8小时,es默认存储时间的格式是UTC时间,如果我们查询es然后获取时间日期默认的数据,会发现跟当前的时间差8个小时,对于es来说这其实是正常的

而我们数据库的存储一般使用GMT+8(中国标准时间)

可以尝试的解决方案:
1、将时间写入ES中string类型字段;
2、将时间以时间戳的形式存入ES中long类型字段;
3、ES默认是UTC时间,将时间+8h后存入ES中date类型字段;
4、写入时间数据时,指定时区,eg:“time”: “2016-07-15T12:58:17.136+0800” //东八区时间

猜你喜欢

转载自blog.csdn.net/weixin_62812758/article/details/128375111