ES使用聚合查询报错exception [type=search_phase_execution_exception, reason=all shards failed]

首先看聚合查询写的代码
在这里插入图片描述
聚合查询 使用的是tags这个字段分组查询,使用term查询。
term查询的话必须查询的字段是keyword类型,而且在java代码后面需要加入.keyword。
text是全文检索,会分词,而keyword不分词查询。
在这里插入图片描述
然后在对应字体加入fielddata=true。

ElasticSearch 5.0以后,string类型有重大变更,移除了string类型,string字段被拆分成两种新的数据类型: text用于全文搜索的,而keyword用于关键词搜索。

ElasticSearch字符串将默认被同时映射成text和keyword类型,将会自动创建下面的动态映射(dynamic mappings):

{

    "foo": {

        "type": "text",

        "fields": {

            "keyword": {

                "type": "keyword",

                "ignore_above": 256

            }

        }

    }

}

这就是造成部分字段还会自动生成一个与之对应的“.keyword”字段的原因。
Text vs. keyword
Text:会分词,然后进行索引

   支持模糊、精确查询

   不支持聚合

keyword:不进行分词,直接索引

   支持模糊、精确查询

   支持聚合
java.lang.IllegalArgumentException: Fielddata is disabled on text fields by default. Set fielddata=true on [interests] in order to load fielddata in memory by uninverting the inverted index. Note that this can however use significant memory. Alternatively use a keyword field instead.

在做聚合时,尝试用text类型的字段做排序,text是需要分词的,分词的话首先字典很大,其次排序是对字典里的词进行排序而不是text类型的词,所以从es5开始就将text类型的字段的fielddata默认设置为false
聚合这些操作用单独的数据结构(fielddata)缓存到内存里了,需要单独开启

你可能感兴趣的:(ElasticSearch)