【问题标题】:TransportError 400 Elasticsearch with huge list of termsTransportError 400 Elasticsearch,包含大量术语
【发布时间】:2016-06-28 18:22:38
【问题描述】:

用少量术语搜索给出我想要的东西

In [29]: small_list
Out[29]: [8096, 8105, 8114, 8116, 8128, 8130]

In [30]: sqs.filter(id__in=small_list)
Out[30]: [<SearchResult: web.listing (pk=u'8128')>, <SearchResult: web.listing (pk=u'8130')>, <SearchResult: web.listing (pk=u'8116')>, <SearchResult: web.listing (pk=u'8105')>, <SearchResult: web.listing (pk=u'8114')>, <SearchResult: web.listing (pk=u'8096')>]

但有数千个术语给出以下错误:

In [32]: len(big_list)
Out[32]: 6305
In [33]: sqs.filter(id__in=big_list)
Traceback (most recent call last):
  File "/home/ravi/bit/wonder/env/local/lib/python2.7/site-packages/haystack/backends/elasticsearch_backend.py", line 516, in search
    _source=True)
  File "/home/ravi/bit/wonder/env/local/lib/python2.7/site-packages/elasticsearch/client/utils.py", line 69, in _wrapped
    return func(*args, params=params, **kwargs)
  File "/home/ravi/bit/wonder/env/local/lib/python2.7/site-packages/elasticsearch/client/__init__.py", line 530, in search
    doc_type, '_search'), params=params, body=body)
  File "/home/ravi/bit/wonder/env/local/lib/python2.7/site-packages/elasticsearch/transport.py", line 307, in perform_request
    status, headers, data = connection.perform_request(method, url, params, body, ignore=ignore, timeout=timeout)
  File "/home/ravi/bit/wonder/env/local/lib/python2.7/site-packages/elasticsearch/connection/http_urllib3.py", line 93, in perform_request
    self._raise_error(response.status, raw_data)
  File "/home/ravi/bit/wonder/env/local/lib/python2.7/site-packages/elasticsearch/connection/base.py", line 105, in _raise_error
    raise HTTP_EXCEPTIONS.get(status_code, TransportError)(status_code, error_message, additional_info)
RequestError: TransportError(400, u'search_phase_execution_exception')

Django==1.8

django-haystack==2.4.1

elasticsearch==2.1.0

【问题讨论】:

  • A 400 错误表示您的查询有问题。捕获并检查异常内部的详细错误消息(异常对象上的.info)以查看它是什么。

标签: python django elasticsearch django-haystack


【解决方案1】:

默认情况下,elasticsearch 对查询词的限制为 1024 个。

以下查询适合您

sqs.filter(id__in=big_list[:1024])

更多信息https://groups.google.com/forum/#!topic/elasticsearch/LqywKHKWbeI

【讨论】:

    猜你喜欢
    • 2017-01-22
    • 2015-02-01
    • 2020-03-19
    • 1970-01-01
    • 1970-01-01
    • 2020-10-25
    • 1970-01-01
    • 2017-11-19
    • 2015-09-24
    相关资源
    最近更新 更多