https://issues.apache.org/activemq/browse/AMQ-2448 - thread leak when network trying to connect to unavailable broker

git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@932403 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Bosanac Dejan 2010-04-09 13:31:36 +00:00
parent 05f82a9b6d
commit 80a7ec59b4
5 changed files with 18 additions and 23 deletions

View File

@ -530,9 +530,6 @@
<!-- breaks hudson: disable till we get a chance to give it the time that it needs - http://hudson.zones.apache.org/hudson/job/ActiveMQ/org.apache.activemq$activemq-core/199/testReport/org.apache.activemq.network/BrokerNetworkWithStuckMessagesTest/testBrokerNetworkWithStuckMessages/ -->
<exclude>**/BrokerNetworkWithStuckMessagesTest.*</exclude>
<!-- until https://issues.apache.org/activemq/browse/AMQ-2448 is fixed -->
<exclude>**/VmTransportNetworkBrokerTest.*</exclude>
</excludes>
</configuration>
</plugin>

View File

@ -109,11 +109,15 @@ public class VMTransport implements Transport, Task {
peer.enqueueValve.decrement();
}
dispatch(peer, transportListener, command);
}
public void dispatch(VMTransport transport, TransportListener transportListener, Object command) {
if( transportListener!=null ) {
if( command == DISCONNECT ) {
transportListener.onException(new TransportDisposedIOException("Peer (" + peer.toString() + ") disposed."));
} else {
peer.receiveCounter++;
transport.receiveCounter++;
transportListener.onCommand(command);
}
}
@ -129,7 +133,7 @@ public class VMTransport implements Transport, Task {
Object command;
while ((command = messageQueue.poll()) != null && !stopping.get() ) {
receiveCounter++;
transportListener.onCommand(command);
dispatch(this, transportListener, command);
}
}
started = true;
@ -150,6 +154,13 @@ public class VMTransport implements Transport, Task {
// If stop() is called while being start()ed.. then we can't stop until we return to the start() method.
if( enqueueValve.isOn() ) {
// let the peer know that we are disconnecting..
try {
peer.transportListener.onException(new TransportDisposedIOException("Peer (" + peer.toString() + ") disposed."));
} catch (Exception ignore) {
}
TaskRunner tr = null;
try {
enqueueValve.turnOff();
@ -168,12 +179,10 @@ public class VMTransport implements Transport, Task {
if (tr != null) {
tr.shutdown(1000);
}
// let the peer know that we are disconnecting..
try {
oneway(DISCONNECT);
} catch (Exception ignore) {
}
}
}
/**

View File

@ -206,16 +206,7 @@ public class VMTransportFactory extends TransportFactory {
public static void stopped(VMTransportServer server) {
String host = server.getBindURI().getHost();
SERVERS.remove(host);
TransportConnector connector = CONNECTORS.remove(host);
if (connector != null) {
LOG.debug("Shutting down VM connectors for broker: " + host);
ServiceSupport.dispose(connector);
BrokerService broker = BROKERS.remove(host);
if (broker != null) {
ServiceSupport.dispose(broker);
}
}
stopped(host);
}
public static void stopped(String host) {

View File

@ -60,6 +60,5 @@
<property name="password" value="${activemq.password}"/>
</bean>
</property>
<property name="useSingleConnection" value="true" />
</bean>
</beans>

View File

@ -58,6 +58,5 @@
<property name="password" value="${activemq.password}"/>
</bean>
</property>
<property name="useSingleConnection" value="true" />
</bean>
</beans>