2

我们正在尝试设置和使用 percolate,但并没有达到预期的效果。

首先,我注册了一些查询:

curl -XPUT 'localhost:9200/index-234234/.percolator/query1' -d '{
    "query" : {
        "range" : {
            "price" : { "gte": 100 }
        }
    }
}'

curl -XPUT 'localhost:9200/index-234234/.percolator/query2' -d '{
    "query" : {
        "range" : {
            "price" : { "gte": 200 }
        }
    }
}'

然后,当我尝试将它与 150 匹配时,理想情况下应该匹配 only query1,而不是匹配两个查询:

curl -XGET 'localhost:9200/index-234234/message/_percolate' -d '{
    "doc" : {
        "price" : 150
    }
}'

{"took":4,"_shards":{"total":5,"successful":5,"failed":0},"total":2,"matches":[{"_index":"index-234234","_id":"query1"},{"_index":"index-234234","_id":"query2"}]}

任何关于为什么会发生这种情况的指针将不胜感激。

4

2 回答 2

5

问题是您在为文档设置映射之前注册过滤器查询。过滤器必须在没有定义映射的情况下注册查询,这可能是一个问题,尤其是对于范围查询。

您应该通过删除索引重新开始,然后首先运行此映射命令:

curl -XPOST localhost:9200/index-234234 -d '{
 "mappings" : {
      "message" : {
        "properties" : {
          "price" : {
            "type" : "long"
          }
        }
      }
    }
}'

然后执行你之前的命令(注册两个 percolator 查询,然后 percolate 一个文档)你会得到以下正确的响应:

{"took":3,"_shards":{"total":5,"successful":5,"failed":0},"total":1,"matches":[{"_index":"index-234234","_id":"query1"}]}

您可能会发现几年前的讨论很有帮助:

http://grokbase.com/t/gg/elasticsearch/124x6hq4ev/range-query-in-percolate-not-working

于 2014-06-15T17:52:24.360 回答
1

不是解决方案,但这对我有用(不知道为什么):

  1. 注册两个渗滤器查询
  2. 执行_percolator请求(返回您的结果"total": 2:)
  3. 再次注册两个过滤器查询(现在都在版本 2 中)
  4. 再次请求(返回正确的_percolator结果:)"total": 1
于 2014-06-15T15:17:10.507 回答