* Fixed bug in the stale connection check
* Tweaked the process of connection allocation for a slightly better readability git-svn-id: https://svn.apache.org/repos/asf/jakarta/httpcomponents/httpclient/trunk@535835 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
c3dcd7651b
commit
16615aa2ab
|
@ -48,6 +48,7 @@ import org.apache.http.client.methods.AbortableHttpRequest;
|
||||||
import org.apache.http.client.params.HttpClientParams;
|
import org.apache.http.client.params.HttpClientParams;
|
||||||
import org.apache.http.conn.BasicManagedEntity;
|
import org.apache.http.conn.BasicManagedEntity;
|
||||||
import org.apache.http.conn.ClientConnectionManager;
|
import org.apache.http.conn.ClientConnectionManager;
|
||||||
|
import org.apache.http.conn.ConnectionPoolTimeoutException;
|
||||||
import org.apache.http.conn.HttpRoute;
|
import org.apache.http.conn.HttpRoute;
|
||||||
import org.apache.http.conn.ManagedClientConnection;
|
import org.apache.http.conn.ManagedClientConnection;
|
||||||
import org.apache.http.conn.RouteDirector;
|
import org.apache.http.conn.RouteDirector;
|
||||||
|
@ -144,22 +145,15 @@ public class DefaultClientRequestDirector
|
||||||
public HttpResponse execute(RoutedRequest roureq, HttpContext context)
|
public HttpResponse execute(RoutedRequest roureq, HttpContext context)
|
||||||
throws HttpException, IOException {
|
throws HttpException, IOException {
|
||||||
|
|
||||||
//@@@ link parameters? Let's rely on the request executor for now.
|
|
||||||
|
|
||||||
HttpResponse response = null;
|
HttpResponse response = null;
|
||||||
boolean done = false;
|
boolean done = false;
|
||||||
|
|
||||||
//@@@ where to put the retry handling and counter?
|
|
||||||
//@@@ here, or retry in a calling method, or retry in an inner loop?
|
|
||||||
//@@@ Retry in a calling method would allow for selecting an alternate
|
|
||||||
//@@@ proxy, but it would not be aware of redirects that have already
|
|
||||||
//@@@ been followed. Would the retry counter apply for each request
|
|
||||||
//@@@ if redirects are followed, or for the whole sequence?
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
int execCount = 0;
|
int execCount = 0;
|
||||||
while (!done) {
|
while (!done) {
|
||||||
allocateConnection(roureq.getRoute());
|
if (managedConn == null) {
|
||||||
|
managedConn = allocateConnection(roureq.getRoute());
|
||||||
|
}
|
||||||
establishRoute(roureq.getRoute(), context);
|
establishRoute(roureq.getRoute(), context);
|
||||||
|
|
||||||
context.setAttribute(HttpExecutionContext.HTTP_TARGET_HOST,
|
context.setAttribute(HttpExecutionContext.HTTP_TARGET_HOST,
|
||||||
|
@ -177,21 +171,21 @@ public class DefaultClientRequestDirector
|
||||||
context.setAttribute(HttpExecutionContext.HTTP_REQUEST,
|
context.setAttribute(HttpExecutionContext.HTTP_REQUEST,
|
||||||
prepreq);
|
prepreq);
|
||||||
|
|
||||||
execCount++;
|
|
||||||
try {
|
|
||||||
if (LOG.isDebugEnabled()) {
|
|
||||||
LOG.debug("Attempt number " + execCount + " to execute request");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (HttpConnectionParams.isStaleCheckingEnabled(params)) {
|
if (HttpConnectionParams.isStaleCheckingEnabled(params)) {
|
||||||
// validate connection
|
// validate connection
|
||||||
LOG.debug("Stale connection check");
|
LOG.debug("Stale connection check");
|
||||||
if (managedConn.isStale()) {
|
if (managedConn.isStale() || execCount == 1) {
|
||||||
LOG.debug("Stale connection detected");
|
LOG.debug("Stale connection detected");
|
||||||
managedConn.close();
|
managedConn.close();
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
execCount++;
|
||||||
|
try {
|
||||||
|
if (LOG.isDebugEnabled()) {
|
||||||
|
LOG.debug("Attempt " + execCount + " to execute request");
|
||||||
|
}
|
||||||
response = requestExec.execute(prepreq, managedConn, context);
|
response = requestExec.execute(prepreq, managedConn, context);
|
||||||
|
|
||||||
} catch (IOException ex) {
|
} catch (IOException ex) {
|
||||||
|
@ -248,17 +242,11 @@ public class DefaultClientRequestDirector
|
||||||
*
|
*
|
||||||
* @throws HttpException in case of a problem
|
* @throws HttpException in case of a problem
|
||||||
*/
|
*/
|
||||||
protected void allocateConnection(HttpRoute route)
|
protected ManagedClientConnection allocateConnection(HttpRoute route)
|
||||||
throws HttpException, IOException {
|
throws HttpException, ConnectionPoolTimeoutException {
|
||||||
|
|
||||||
// we assume that the connection would have been released
|
|
||||||
// if it was not appropriate for the route of the followup
|
|
||||||
if (managedConn != null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
long timeout = HttpClientParams.getConnectionManagerTimeout(params);
|
long timeout = HttpClientParams.getConnectionManagerTimeout(params);
|
||||||
managedConn = connManager.getConnection(route, timeout);
|
return connManager.getConnection(route, timeout);
|
||||||
|
|
||||||
} // allocateConnection
|
} // allocateConnection
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue