ES批量请求`es_rejected_execution_exception`

php小编苹果为您介绍ES批量请求中的常见问题:`es_rejected_execution_exception`。在使用Elasticsearch进行批量请求时,有时会遇到这个异常。这个异常通常表示请求的并发数超过了Elasticsearch服务器的处理能力,导致请求被拒绝执行。本文将为您解析这个异常的原因,并给出解决方案,帮助您顺利处理该问题。,我有一个大约 5M 条目的切片(为简单起见,假设每个条目都是一个字节切片,它使用 getIndexerItem 函数映射到索引器项),我将其平均分配给 200 个 go 例程。然后每个go例程调用push函数,切片长度为5M/200。,根据我对Refresh的理解:wait_for,每当向elastic发出请求时,只有当该请求所做的更改对搜索可见时才会完成(IMO将其转换为不再有此特定请求的批量请求队列) )。那为什么我会收到此错误?,所有条目都将进入相同的索引,ankit-test。,假设没有其他进程以任何方式与索引交互。,使用多个 ES 文档,我能够找到上述问题的解决方案。下面的回答是基于我的理解。如果您发现可以改进/纠正的内容,请发表评论。,这是请求生命周期:,我的问题是我使用 refresh = false (默认)发送请求。相反,应该使用 refresh = wait_for 。为什么?刷新提供了3种模式:,所有数据都被重定向到同一节点,并且由于 refresh = false,在现有请求从队列中清除之前返回了响应,这导致了溢出。,
返回顶部
跳到底部

Copyright 2011-2024 南京追名网络科技有限公司 苏ICP备2023031119号-6 乌徒帮 All Rights Reserved Powered by Z-BlogPHP Theme By open开发

请先 登录 再评论,若不是会员请先 注册