AWS Elasticsearch扩大规模

问题描述

我正在使用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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...