【Elasticsearch】Request cannot be executed;I/O reactor status :STOPPED.

在这里插入图片描述

1.概述

转载:https://bbs.huaweicloud.com/forum/thread-70234-1-1.html

我也曾经遇到这个错误,但是忘记记录了,现在转载记录

多线程并发写入ES时,连接断开,反馈的报错是error while performing request。修改DEFAULT_CONNECTION_REQUEST_TIMEOUT_MILLIS=-1后,报错Request cannot be executed;I/O reactor status :STOPPED.

2.原因分析

RestClient中的参数DEFAULT_CONNECTION_REQUEST_TIMEOUT_MILLIS参数设置的较小,可能会导致http连接池获取连接超时。

RestClient调用CloseableHttpAsyncClient执行请求,在执行之初,就会判断status,如果不是active,那么就会报上面的错误。

而报错中status是STOPPED,也就是被关闭了,大概率是业务程序中多个线程共享restclient,某个线程调用完restclient后关闭了,导致其他线程再去发送请求时报错。

3.解决办法

ISV侧整改业务代码,勿在线程中释放进程中创建的RestClient资源。

相关参考:

【es】ES RestHighLevelClient 请求报错:Connection reset by peer

猜你喜欢

转载自blog.csdn.net/qq_21383435/article/details/114000012
今日推荐