ElasticSearch.js搜索查询返回0次点击,但生成的URL包含正确的点击

时间:2017-07-12 16:23:34

标签: javascript elasticsearch elasticsearch.js

我目前正在用JavaScript编写一个网站,用ElasticSearch中的数据绘制各种字段,我遇到了一个奇怪的问题。 (出于各种原因,我不想使用Kibana。)

我在JavaScript中的搜索查询已经正常回复,直到很久以前。我没有对它做任何更改,但突然查询没有返回任何命中。但是,当我按照呼叫生成的URL时,会出现我想要的匹配。

以下是查询:

        client.search({
        index: "chamber-data",
        type: "Soak1",
        size: 1000,
        scroll: "30s",
        sort: ["_doc"],
        _source: ["@timestamp", "datetime", [...this.props.fields]],
        body: {
            query: {
                bool: {
                    filter: {
                        range: {
                            "datetime": {
                                lte: "now",
                                gte: "now-12H"
                            }
                        }
                    }
                }
            }
        }
    }).then(this.process_promise, this.handle_error);

以下是脚本在我的网站控制台中提供的内容:

  {
"_scroll_id": "DnF1ZXJ5VGhlbkZldGNoBQAAAAAAA1NrFlZYTEJLYW12UUFTaWowMllJZVcyalEAAAAAAANTbRZWWExCS2FtdlFBU2lqMDJZSWVXMmpRAAAAAAADU28WVlhMQkthbXZRQVNpajAyWUllVzJqUQAAAAAAA1NsFlZYTEJLYW12UUFTaWowMllJZVcyalEAAAAAAANTbhZWWExCS2FtdlFBU2lqMDJZSWVXMmpR",
"took": 0,
"timed_out": false,
"_shards": {
  "total": 5,
  "successful": 5,
  "failed": 0
},
"hits": {
  "total": 0,
  "max_score": null,
  "hits": []
}

}

以下是网址给我的内容:

{"_scroll_id":"DnF1ZXJ5VGhlbkZldGNoBQAAAAAAA1N2FlZYTEJLYW12UUFTaWowMllJZVcyalEAAAAAAANTdBZWWExCS2FtdlFBU2lqMDJZSWVXMmpRAAAAAAADU3cWVlhMQkthbXZRQVNpajAyWUllVzJqUQAAAAAAA1NzFlZYTEJLYW12UUFTaWowMllJZVcyalEAAAAAAANTdRZWWExCS2FtdlFBU2lqMDJZSWVXMmpR",
    "took":9,
    "timed_out":false,
    "_shards":{"total":5,"successful":5,"failed":0},
    "hits":
    {"total":107565,"max_score":null,"hits":[...]}
    }

我完全不知道发生了什么,我不知道如何解决它。有人有想法吗?

1 个答案:

答案 0 :(得分:0)

在我的情况下,我有一个测试脚本,它使用bulk api加载一堆记录,并在此之后查询ES。对于外部/手动客户端(Postman)一切正常,但没有使用js客户端命中,在插入后立即在脚本中调用。

问题在于新插入的文档的索引needs to be refreshed出现在搜索中(IndexUpdateDelete API也是如此)。

我在批量通话后解决了强制刷新问题。

client.bulk({
  refresh: true, // This is the important part
  body: [
    // Bunch of documents/actions
  ]
}, function (err, resp) {
  // ...
})