在Elasticsearch中对 text 类型的字段进行聚合异常Fielddata is disabled,Set fielddata=true...

1.问题: 


1. 在Elasticsearch中对 text 类型的字段进行聚合,报异常:

脚本调用: 

GET /logstash-jsy/nginx-access/_search 

  "aggs": { 
    "all_interests": { 
      "terms": { "field": "geoip.city_name" } 
    } 
  } 
}
    

    java.lang.IllegalArgumentException: Fielddata is disabled on text fields by default. Set fielddata=true on [geoip.city_name] 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.
    at org.elasticsearch.index.mapper.TextFieldMapper$TextFieldType.fielddataBuilder(TextFieldMapper.java:336)

 

2. 原因, 默认 Elasticsearch 对 text 类型的字段是不可聚合的,基本类型可聚合

 

3. 解决

            a. 设置   Fielddata = true 
            
PUT logstash-jsy/_mapping/nginx-access/
{
  "properties": {
    "geoip.city_name": { 
      "type":     "text",
      "fielddata": true
    }
  }
}
            
            
            b. 如果 Fielddata = true 无法解决, 使用使用keyword
            
            
    查看你索引信息字段是否是这种多映射, req_url 字段既映射了  text , 又映射了 keyword
    
    
    "req_url": {

    "norms": false,
    "type": "text",
    "fields": {
        "keyword": {
            "type": "keyword"
        }
    }

}
如果是: 
        https://www.elastic.co/guide/en/elasticsearch/reference/5.4/fielddata.html#before-enabling-fielddata
    
    Use the my_field.keyword field for aggregations, sorting, or in scripts.
    即:  字段.keyword  
            
GET /logstash-jsy/nginx-access/_search 

  "aggs": { 
    "all_interests": { 
      "terms": { "field": "geoip.city_name.keyword" } 
    } 
  } 
}


TermsAggregationBuilder teamAgg = AggregationBuilders.terms("cityName_count")
                    .field("geoip.country_name.keyword").size(15);
searchResponse = elasticsearchConfig.getObject().prepareSearch(EsConstant.INDEX_NAME)
                    .setTypes(EsConstant.TYPE_NAME).setQuery(null).addAggregation(teamAgg).setSize(0).execute()
                    .actionGet();
            
            
            c. 如果还无法解决
            
                http://www.cnblogs.com/Creator/p/3722408.html

                https://elasticsearch.cn/question/2031?notification_id=14626&comment_unfold=question
    

转载于:https://my.oschina.net/u/193184/blog/1505175

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值