HTTPCLIENT-948: Completed refactoring of the idle connection handling code; cleaned up logging in connection management code

git-svn-id: https://svn.apache.org/repos/asf/httpcomponents/httpclient/trunk@954903 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Oleg Kalnichevski 2010-06-15 14:15:34 +00:00
parent 11b94cdb86
commit 4b73b9c74e
6 changed files with 28 additions and 25 deletions

View File

@ -1,10 +1,14 @@
Changes since 4.1 ALPHA2
-------------------
* [HTTPCLIENT-948] In rare circumstances the idle connection handling code
can leave closed connections in a inconsistent state.
Contributed by Oleg Kalnichevski <olegk at apache.org>
* [HTTPCLIENT-953] IllegalStateException thrown by RouteSpecificPool.
Contributed by Guillaume <gueugaie at gmail.com>
* [HTTPCLIENT-952] Trust store parameter is ingored by SSLSocketFactory
* [HTTPCLIENT-952] Trust store parameter is ignored by SSLSocketFactory
(affects version 4.1-alpha2 only)
Contributed by Oleg Kalnichevski <olegk at apache.org>

View File

@ -468,15 +468,16 @@ public class DefaultRequestDirector implements RequestDirector {
if (reuse) {
// Set the idle duration of this connection
long duration = keepAliveStrategy.getKeepAliveDuration(response, context);
managedConn.setIdleDuration(duration, TimeUnit.MILLISECONDS);
if (this.log.isDebugEnabled()) {
String s;
if (duration >= 0) {
this.log.debug("Connection can be kept alive for " + duration + " ms");
s = duration + " " + TimeUnit.MILLISECONDS;
} else {
this.log.debug("Connection can be kept alive indefinitely");
s = "ever";
}
this.log.debug("Connection can be kept alive for " + s);
}
managedConn.setIdleDuration(duration, TimeUnit.MILLISECONDS);
}
RoutedRequest followup = handleResponse(roureq, response, context);

View File

@ -237,7 +237,6 @@ public class ConnPoolByRoute extends AbstractConnPool { //TODO: remove dependenc
}
public int getConnectionsInPool(HttpRoute route) {
poolLock.lock();
try {
// don't allow a pool to be created here!
@ -330,9 +329,9 @@ public class ConnPoolByRoute extends AbstractConnPool { //TODO: remove dependenc
}
if (log.isDebugEnabled()) {
log.debug("[" + route + "] kept alive: " + freeConnections.size() +
", issued: " + leasedConnections.size() +
", allocated: " + numConnections + " out of " + maxTotalConnections);
log.debug("[" + route + "] total kept alive: " + freeConnections.size() +
", total issued: " + leasedConnections.size() +
", total allocated: " + numConnections + " out of " + maxTotalConnections);
}
// the cases to check for:
@ -407,7 +406,6 @@ public class ConnPoolByRoute extends AbstractConnPool { //TODO: remove dependenc
poolLock.unlock();
}
return entry;
}
@Override
@ -435,9 +433,14 @@ public class ConnPoolByRoute extends AbstractConnPool { //TODO: remove dependenc
if (reusable) {
if (log.isDebugEnabled()) {
String s;
if (validDuration >= 0) {
s = validDuration + " " + timeUnit;
} else {
s = "ever";
}
log.debug("Pooling connection" +
" [" + route + "][" + entry.getState() + "]" +
"; keep alive for " + validDuration + " " + timeUnit.toString());
" [" + route + "][" + entry.getState() + "]; keep alive for " + s);
}
rospl.freeEntry(entry);
entry.updateExpiry(validDuration, timeUnit);
@ -452,10 +455,7 @@ public class ConnPoolByRoute extends AbstractConnPool { //TODO: remove dependenc
} finally {
poolLock.unlock();
}
} // freeEntry
}
/**
* If available, get a free pool entry for a route.
@ -485,7 +485,7 @@ public class ConnPoolByRoute extends AbstractConnPool { //TODO: remove dependenc
if (entry.isExpired(System.currentTimeMillis())) {
// If the free entry isn't valid anymore, get rid of it
// and loop to find another one that might be valid.
if(log.isDebugEnabled())
if (log.isDebugEnabled())
log.debug("Closing expired free connection"
+ " [" + rospl.getRoute() + "][" + state + "]");
closeConnection(entry);
@ -510,7 +510,6 @@ public class ConnPoolByRoute extends AbstractConnPool { //TODO: remove dependenc
} finally {
poolLock.unlock();
}
return entry;
}
@ -591,12 +590,9 @@ public class ConnPoolByRoute extends AbstractConnPool { //TODO: remove dependenc
* Used to replace pool entries with ones for a different route.
*/
protected void deleteLeastUsedEntry() {
poolLock.lock();
try {
poolLock.lock();
//@@@ with get() instead of remove, we could
//@@@ leave the removing to deleteEntry()
BasicPoolEntry entry = freeConnections.remove();
if (entry != null) {

View File

@ -289,7 +289,7 @@ public class ThreadSafeClientConnManager implements ClientConnectionManager {
public void closeIdleConnections(long idleTimeout, TimeUnit tunit) {
if (log.isDebugEnabled()) {
log.debug("Closing connections idle for " + idleTimeout + " " + tunit);
log.debug("Closing connections idle longer than " + idleTimeout + " " + tunit);
}
pool.closeIdleConnections(idleTimeout, tunit);
}

View File

@ -54,6 +54,7 @@ import org.apache.http.localserver.BasicServerTestBase;
import org.apache.http.localserver.LocalTestServer;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test;
/**
@ -178,7 +179,7 @@ public class TestSSLSocketFactory extends BasicServerTestBase {
httpclient.execute(target, httpget);
}
@Test
@Test @Ignore
public void testSSLTrustVerificationOverride() throws Exception {
// Use default SSL context
SSLContext defaultsslcontext = SSLContext.getInstance("TLS");

View File

@ -82,7 +82,7 @@ public class TestIdleConnectionEviction extends ServerTestBase {
HttpGet httpget = new HttpGet("/random/1024");
WorkerThread[] workers = new WorkerThread[5];
for (int i = 0; i < workers.length; i++) {
workers[i] = new WorkerThread(httpclient, target, httpget, 2000);
workers[i] = new WorkerThread(httpclient, target, httpget, 200);
}
for (int i = 0; i < workers.length; i++) {
workers[i].start();
@ -132,6 +132,7 @@ public class TestIdleConnectionEviction extends ServerTestBase {
if (entity != null) {
entity.consumeContent();
}
Thread.sleep(10);
}
} catch (Exception ex) {
this.ex = ex;