我目前正在用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":[...]}
}
我完全不知道发生了什么,我不知道如何解决它。有人有想法吗?
答案 0 :(得分:0)
在我的情况下,我有一个测试脚本,它使用bulk
api加载一堆记录,并在此之后查询ES。对于外部/手动客户端(Postman)一切正常,但没有使用js客户端命中,在插入后立即在脚本中调用。
问题在于新插入的文档的索引needs to be refreshed出现在搜索中(Index
,Update
和Delete
API也是如此)。
我在批量通话后解决了强制刷新问题。
client.bulk({
refresh: true, // This is the important part
body: [
// Bunch of documents/actions
]
}, function (err, resp) {
// ...
})