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资源。
相关参考: