ruby-on-railsrubyelasticsearchelasticsearch-model

Don't know how to sort elasticsearch-model results


I'm using elasticsearch-model on my RoR application to perform a search and have the results sorted. I can perform the query and have back unsorted results, but when I add sort everything breaks with:

Elasticsearch::Transport::Transport::Errors::BadRequest: [400] {"error":{"root_cause":[{"type":"illegal_argument_exception","reason":"Fielddata is disabled on text fields by default. Set fielddata=true on [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."}],"type":"search_phase_execution_exception","reason":"all shards failed","phase":"query","grouped":true,"failed_shards":[{"shard":0,"index":"profiles","node":"mad6gavaR3yTFabsF9m0rg","reason":{"type":"illegal_argument_exception","reason":"Fielddata is disabled on text fields by default. Set fielddata=true on [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."}}]},"status":400}
from /Users/ngw/.rvm/gems/ruby-2.2.2@utelier/gems/elasticsearch-transport-5.0.4/lib/elasticsearch/transport/transport/base.rb:202:in `__raise_transport_error'

which apparently is telling me that the way I configured the indexes is wrong. Here is what I'm indexing

def as_indexed_json(options={})
  {
    profile_type:     profile_type,
    name:             name,
    specialisation:   specialisation,
    description:      description,
    tags:             tags,
    minimum_order:    minimum_order,
    company_city:     company_city,
    company_address:  company_address,
    continent_id:     country.try(:continent).try(:id),
    country_id:       country.try(:id),
    industry:         industry.try(:id)
  }
end

A query can use any of these fields, but not :name, which is only used for sorting purposes. The configuration of my index is very simple:

settings index: { number_of_shards: 1 } do
  mapping dynamic: false do
    indexes :name, type: 'text'
    indexes :description, analyzer: 'english'
  end
end

I'm pretty sure my indexes are setup wrong, but after searching for some time inside elasticsearch-model tests I can't find anything relevant. Can someone help me figure this out? Thanks in advance.


Solution

  • Sure the problem is that the type of name is text. From elastic search 5 you can't sort on an analyzed field by default

    Sorting can be either done on fields with field_data or doc_values enabled -> the data structure elasticsearch uses for sorting and aggregation.

    You can do two things

    https://www.elastic.co/guide/en/elasticsearch/reference/current/fielddata.html

    https://www.elastic.co/guide/en/elasticsearch/reference/current/doc-values.html