问题描述
我正在使用AWS Elasticsearch Service,并且得到了很多es_rejected_execution_exception
。
根据他们的docs,我们应该提高应用程序的索引性能,添加更多节点或切换到更大的实例类型。
如果我精疲力竭地改进应用程序,那么添加更多节点或切换到大型实例类型哪个更好?
解决方法
第一个也是最重要的一点是,es_rejected_execution_exception
是所有threadpools in ES的通用异常,并且只要它们的队列容量超过此异常,就会抛出该异常,并且AWS文档提供了bulk
队列的示例在例外之后在简短说明中以es_rejected_execution_exception[bulk]
注释bulk
的形式提及。
请注意,ES中有很多线程池,但是最重要且使用最频繁的线程池是搜索和写入(在最新版本中,批量调用也使用写入队列),并且您需要仔细查看异常消息以了解哪个队列正在耗尽,以便您知道需要优化的内容。
增加队列大小是一个有争议的主题,但是如果您的请求短暂爆发,则可以增加队列大小,这在AWS ES中也是不可能的:(
您总是可以增加硬件,但应该找到根本原因,加以解决,并优化索引和搜索操作,以减少硬件消耗并节省$$$,请参考我对improve search的简短提示和index performance