ERROR > ES : too_many_clauses: maxClauseCount is set to 1024

ES
在查询 Elasticseach 时,报错:

too_many_clauses: maxClauseCount is set to 1024

原因可能有2种,分别是:
1、查询语句中的 bool 查询的条件过多
2、查询语句中的 bool 查询的字符过多

相应的解决方法:
1、拆分查询语句中的 bool 查询条件,修改为多个小的 bool 条件组合的方式
2、在 elasticsearch.yml 配置中调大对 bool 的限制,修改方式如下:

对 Elasticsearch 5.0 以下的版本,在配置中添加或修改:

index.query.bool.max_clause_count: 10240

对 Elasticsearch 5.0 以上的版本,在配置中添加或修改:

indices.query.bool.max_clause_count: 10240

最佳实践:
建议不要直接设置为10240,考虑到不同系统的编码情况不同,在业务满足的条件下,建议设置为 10200 / 3 = 3400

修改配置后,重启ES即可正常。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值