我有一个非常奇怪的情况
在将文档发送到ES索引并创建文档之后,文档中的一些字段会立即出现,而另一些字段则会延迟出现。也就是说,某些字段具有null、[]和0(取决于字段类型),而不是发送到索引的值。
5-10分钟后,这些字段将填充实际值。
当我批量处理大量文档(最多500个)时,就会出现这种情况。当我逐个发送文档时,这并没有发生。
在谷歌上搜索这个问题并没有给出任何结果。
在索引或批量设置中可以进行哪些更改,以便在搜索中不显示为空值的文档?
Elasticsearch版本: 7.6.0
更新:
为了了解更多上下文,我添加了打印屏幕:
1)这是文档添加后立即在Kibana中的外观:

2)所以文档在5-10分钟后看起来:

在索引设置中,将refresh_interval设置为1s
将refresh = "wait_for"添加到批量请求不会更改任何内容
发布于 2020-05-30 09:57:49
请检查您的索引的refresh parameter,默认值为1秒,但可以调整。此外,请检查当您逐个发送时,您没有执行显式刷新或在请求中使用wait_for参数。
根据official doc wait_for param的说法
等待刷新使请求所做的更改可见,然后再进行回复。这并不是强制立即刷新,而是等待刷新发生。Elasticsearch自动刷新每隔一次更改的分片
解决方案:对于您的批量请求,使用wait_for参数,使用此参数直到刷新发生时才返回结果,并且一旦您获得响应,您发送的值将可用于搜索。
https://stackoverflow.com/questions/62093208
复制相似问题