Incorrect handling of NoHttpResponseException in DefaultHttpMethodRetryHandler
------------------------------------------------------------------------------
Key: HTTPCLIENT-886
URL: https://issues.apache.org/jira/browse/HTTPCLIENT-886
Project: HttpComponents HttpClient
Issue Type: Bug
Affects Versions: 3.1 Final
Reporter: Sylvain Laurent
Priority: Critical
Fix For: 3.1.1
We have a buggy load-balancer that sometimes forwards the request to the
back-end server, and then close the connections without returning any data at
all.
This provokes a NoHttpResponseException inside commons http client 3.1, which
is handled by DefaultHttpMethodRetryHandler.
Unfortunately DefaultHttpMethodRetryHandler handles this
NoHttpResponseException by asking for a retry. In our case, this is very
dangerous because the request has already been sent and is being processed by
the back-end server.
I think that in the case of a NoHttpResponseException the test
!method.isRequestSent() shoud be done :
if (exception instanceof NoHttpResponseException &&
!method.isRequestSent()) {
// Retry if the server dropped connection on us AND the request was
not sent
return true;
}
--
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]