elasticSearch 时间类型
来源:互联网 发布:tornado和nginx 编辑:程序博客网 时间:2024/06/05 18:16
Elasticsearch Date类型使用技巧
elasticsearch原生支持date类型,结合该类型和Kibana可以做出漂亮有用的图表。这里简单记录下使用的方法。
使用date类型可以用如下两种方式:
使用毫秒的时间戳,直接将毫秒值传入即可。
传入格式化的字符串,默认是ISO 8601标准,例如
2015-02-27T00:07Z
(零时区)、2015-02-27T08:07+08:00
(东八区),这两个时间实际是同一个,只是时区不同,关于时间戳,可以参见我之前的文章。另外还可以自定义时间格式,参见es的文档。但个人不建议使用自定义格式,设置不当容易遇到时区问题。在php中获取ISO 8601
标准的时间很简单,date('c',time())
即可。
elasticsearch默认会自动识别date类型,如果想关闭该功能,修改mapping的设置'date_detection' => false
即可 。
elasticsearch原生支持date类型,json格式通过字符来表示date类型。所以在用json提交日期至elasticsearch的时候,es会隐式转换,把es认为是date类型的字符串直接转为date类型。至于什么样的字符串es会认为可以转换成date类型,参考elasticsearch官网介绍https://www.elastic.co/guide/en/elasticsearch/reference/current/mapping-date-format.html。
date类型是包含时区信息的,如果我们没有在json代表日期的字符串中显式指定时区,对es来说没什么问题,但是如果通过kibana显示es里的数据时,就会出现问题,数据的时间会晚8个小时。因为kibana从es里读取的date类型数据,没有时区信息,kibana会默认当作0时区来解析,但是kibana在通过浏览器展示的时候,会通过js获取当前客户端机器所在的时区,也就是东八区,所以kibana会把从es得到的日期数据减去8小时。这里就会导致kibana经常遇到的“数据时间延迟8小时”的问题。
所以最佳实践方案就是:我们在往es提交日期数据的时候,直接提交带有时区信息的日期字符串,如:“2016-07-15T12:58:17.136+0800”。
- elasticSearch 时间类型
- Elasticsearch Date类型,时间存储相关说明
- elasticsearch搜索类型简介
- Elasticsearch的field类型。
- Java - Elasticsearch查询类型
- elasticsearch 索引 类型 id
- ElasticSearch索引自定义类型
- Elasticsearch节点类型
- Elasticsearch节点类型
- elasticsearch 默认索引类型
- Elasticsearch之深入类型。
- elasticsearch-mapping字段类型
- elasticsearch 时间查询语法
- Elasticsearch Date类型使用技巧
- Elasticsearch支持的字段类型
- Elasticsearch搜索类型SearchType详解
- Elasticsearch搜索类型(SearchType)详解
- grafana elasticsearch date类型问题
- 二分查找的递归和非递归实现
- 安卓activity与task
- spring知识点(个人记录)
- redigo代码分析-特殊字符
- PCA原理分析
- elasticSearch 时间类型
- sky3888 Register And Play Free The Wish Master Slot Game(ibet, malaysia online casino, sky3888 regi)
- OSGI企业应用开发(一)OSGI简介
- 银联交易中撤销和退货的区别
- UNIX再学习 -- 进程环境
- 改变FragmentTabHost选中的文字颜色。
- spring mvc常用注解标签
- C++实现双向循环链表
- LeetCode (Roman to Integer)